我正在尝试将Jython与mysql连接。我下载了“zxJDBC.jar”,“mm.mysql-2.0.4-bin.jar”和“mysql-connector-java-5.1.20-bin.jar”,并将它们的路径设置为CLASSPATH。
在我的Jython脚本中,两者都是
$from com.ziclix.python.sql import zxJDBC
$from org.gjt.mm.mysql import Driver
通过。
但是什么时候
$conn = zxJDBC.connect("jdbc:mysql://localhost/automobile2", "root", "nihaonlp", "org.gjt.mm.mysql.Driver")
翻译告诉我
$zxJDBC.DatabaseError: driver [org.gjt.mm.mysql.Driver] not found
如何解决?
ħ
答案 0 :(得分:1)
看看这里:
http://glasblog.1durch0.de/?p=846
基本上,这个技巧会使用ClassLoader加载你的类,以便你可以在jython中使用它
http://www.jython.org/jythonbook/en/1.0/appendixB.html#using-the-classpath-steve-langer
我建议稍微修改脚本:
class classPathHacker:
##########################################################
# from http://forum.java.sun.com/thread.jspa?threadID=300557
#
# Author: SG Langer Jan 2007 translated the above Java to this
# Jython class
# Modified 2012 by Malte Vesper
# Purpose: Allow runtime additions of new Class/jars either from
# local files or URL
######################################################
import java.lang.reflect.Method
import java.io.File
import java.net.URL
import java.net.URLClassLoader
import jarray
def addFile (self, path):
#############################################
# Purpose: If adding a file/jar call this first
# with path = path_to_jar
#############################################
return self.addURL (self.java.io.File (path).toUrl())
def addURL (self, url):
##################################
# Purpose: Call this with u= URL for
# the new Class/jar to be loaded
#################################
parameters = self.jarray.array([self.java.net.URL], self.java.lang.Class)
sysloader = self.java.lang.ClassLoader.getSystemClassLoader()
sysclass = self.java.net.URLClassLoader
method = sysclass.getDeclaredMethod("addURL", parameters)
jar_a = self.jarray.array([url], self.java.lang.Object)
method.invoke(sysloader, jar_a)
return url
答案 1 :(得分:0)
我来到这里寻找同样错误的解决方案。问题是我在Eclipse Luna和pydev + jython中运行。从我在别处读到的内容,IDE忽略了classpath环境变量,因为缺乏可移植性而被认为是不好的做法。
无论如何,eclipse / pydev对于初学者来说相当沉重,我花了一些时间来找出解决方案,我想分享它。
所以,安装驱动程序之后,可以去任何地方,但是当前的Windows版本都有一个msi安装程序,它将把它放在Program Files(x86)\ Mysql下。
在Eclipse中,转到Window-> Prefences-> PyDev-> Interpreters-> Jython Interpreter。
在这里,查找面板库(通常默认打开)并选择New Jar按钮。浏览以找到已安装的驱动程序的jar并选择它。这应该将jar添加到列表中,然后在运行时找到驱动程序。