因为我想将我最近的Minecraft Python / Jython Bukkit插件的数据存储从平面文件转换为MySQL数据库,所以我开始使用Google搜索。尝试了Python的sqlite3和MySQLd但没有成功,所以经过几个小时的搜索StackOverflow,我找到了这个问题和答案,它应该解决我的问题,因为它是一回事。我尝试按照this answer中给出的步骤进行操作,但由于此错误没有成功:
[15:31:45 WARN]: org.bukkit.plugin.InvalidPluginException: Traceback (most recen
t call last):
File "<iostream>", line 10, in <module>
zxJDBC.DatabaseError: unable to instantiate datasource
[15:31:45 WARN]: at net.lahwran.bukkit.jython.PythonPluginLoader.loadPlug
in(PythonPluginLoader.java:296)
[15:31:45 WARN]: at net.lahwran.bukkit.jython.PythonPluginLoader.loadPlug
in(PythonPluginLoader.java:113)
[15:31:45 WARN]: at net.lahwran.bukkit.jython.PythonPluginLoader.loadPlug
in(PythonPluginLoader.java:83)
[15:31:45 WARN]: at org.bukkit.plugin.SimplePluginManager.loadPlugin(Simp
lePluginManager.java:305)
[15:31:45 WARN]: at com.master.bukkit.python.PythonLoader.onLoad(PythonLo
ader.java:113)
[15:31:45 WARN]: at org.bukkit.craftbukkit.v1_7_R1.CraftServer.loadPlugin
s(CraftServer.java:260)
[15:31:45 WARN]: at org.bukkit.craftbukkit.v1_7_R1.CraftServer.reload(Cra
ftServer.java:628)
[15:31:45 WARN]: at org.bukkit.Bukkit.reload(Bukkit.java:279)
[15:31:45 WARN]: at org.bukkit.command.defaults.ReloadCommand.execute(Rel
oadCommand.java:23)
[15:31:45 WARN]: at org.bukkit.command.SimpleCommandMap.dispatch(SimpleCo
mmandMap.java:192)
[15:31:45 WARN]: at org.bukkit.craftbukkit.v1_7_R1.CraftServer.dispatchCo
mmand(CraftServer.java:542)
[15:31:45 WARN]: at org.bukkit.craftbukkit.v1_7_R1.CraftServer.dispatchSe
rverCommand(CraftServer.java:529)
[15:31:45 WARN]: at net.minecraft.server.v1_7_R1.DedicatedServer.aw(Dedic
atedServer.java:286)
[15:31:45 WARN]: at net.minecraft.server.v1_7_R1.DedicatedServer.u(Dedica
tedServer.java:251)
[15:31:45 WARN]: at net.minecraft.server.v1_7_R1.MinecraftServer.t(Minecr
aftServer.java:541)
[15:31:45 WARN]: at net.minecraft.server.v1_7_R1.MinecraftServer.run(Mine
craftServer.java:453)
[15:31:45 WARN]: at net.minecraft.server.v1_7_R1.ThreadServerApplication.
run(SourceFile:617)
我使用的代码导致上面的错误:
from com.ziclix.python.sql import zxJDBC
params = {}
params['serverName'] = 'host'
params['databaseName'] = 'dbname'
params['user'] = "username"
params['password'] = "pw"
params['port'] = 3306
db = apply(zxJDBC.connectx, ("org.gjt.mm.mysql.MysqlDataSource",), params)
另外,我尝试了这段代码:
from com.ziclix.python.sql import zxJDBC
d, u, p, v = "jdbc:mysql://host", "root", "pw", "org.gjt.mm.mysql.Driver"
db = zxJDBC.connect(d, u, p, v)
但是它导致了这个错误:
[15:37:20 WARN]: Caused by: Traceback (most recent call last):
File "<iostream>", line 13, in <module>
zxJDBC.DatabaseError: driver [org.gjt.mm.mysql.Driver] not found
[15:37:20 WARN]: at org.python.core.PyException.doRaise(PyException.java:
200)
[15:37:20 WARN]: at org.python.core.Py.makeException(Py.java:1239)
[15:37:20 WARN]: at org.python.core.Py.makeException(Py.java:1243)
[15:37:20 WARN]: at com.ziclix.python.sql.zxJDBC.makeException(zxJDBC.jav
a:328)
[15:37:20 WARN]: at com.ziclix.python.sql.connect.Connect.__call__(Connec
t.java:78)
[15:37:20 WARN]: at org.python.core.PyObject.__call__(PyObject.java:441)
[15:37:20 WARN]: at org.python.core.PyObject.__call__(PyObject.java:447)
[15:37:20 WARN]: at org.python.pycode._pyx5.f$0(<iostream>:15)
[15:37:20 WARN]: at org.python.pycode._pyx5.call_function(<iostream>)
[15:37:20 WARN]: at org.python.core.PyTableCode.call(PyTableCode.java:165
)
[15:37:20 WARN]: at org.python.core.PyCode.call(PyCode.java:18)
[15:37:20 WARN]: at org.python.core.Py.runCode(Py.java:1275)
[15:37:20 WARN]: at org.python.util.PythonInterpreter.execfile(PythonInte
rpreter.java:235)
[15:37:20 WARN]: at org.python.util.PythonInterpreter.execfile(PythonInte
rpreter.java:230)
[15:37:20 WARN]: at net.lahwran.bukkit.jython.PythonPluginLoader.loadPlug
in(PythonPluginLoader.java:244)
[15:37:20 WARN]: ... 16 more
我做了什么(一步一步)?
我从this link下载了压缩的mysql连接器/ J(如已经链接的SO问题的回答),解压缩,复制&#34; mysql-connector-java-3.1.14-bin.jar&# 34;从它,粘贴到此路径&#34; C:\ Users \ my_name \ Documents \ 1.7.2twistedjobs \ plugins \ MySQL_jython&#34;。之后,我打开控制面板,单击系统,转到高级系统设置,单击环境变量按钮,添加新的命名CLASSPATH(因为没有该名称的变量),并将此路径设置为值&#34; C:\ Users \ my_name \ Documents \ 1.7.2twistedjobs \ plugins \ MySQL_jython \ mysql-connector-java-3.1.14-bin.jar&#34;,点击确定。
注意:由于zxJDBC没有导入错误,这很奇怪,因为它显然已成功导入它,但无法找到驱动程序......
提前致谢!
答案 0 :(得分:0)
您的第二段代码应该可以使用。它适用于我的机器。你看起来有一个CLASSPATH问题。您可以尝试将MySQL驱动程序jar文件放在扩展目录中,在Windows上可以找到它:
%SystemRoot%\Sun\Java\lib\ext
然后,驱动程序将可用于所有Java应用程序(如果这是您想要的)。详细信息在Oracle的文档中:
http://docs.oracle.com/javase/tutorial/ext/basics/install.html
我想提出其他几点。首先,即使驱动程序使用您提供的名称,您最终也可能希望将其从org.gjt.mm.mysql.Driver
更改为com.mysql.jdbc.Driver
,这是现代的重命名版本。 (如果您对原因感兴趣,详细信息请点击此处:https://stackoverflow.com/a/5808184/155167。)
您的第一段代码无效,因为MysqlDataSource
包中没有org.gjt.mm.mysql
类。您引用的那个课程实际上是com.mysql.jdbc.jdbc2.optional.MysqlDataSource
,但我不知道 代码段是否有效。
就像我说的那样,将MySQL驱动程序jar正确放入CLASSPATH中,它应该可行。有关CLASSPATH设置的Oracle文档如下:
http://docs.oracle.com/javase/tutorial/essential/environment/paths.html http://docs.oracle.com/javase/8/docs/technotes/tools/windows/classpath.html
祝你好运!