繁体   English   中英

连接mysql和Java的问题

[英]Problem to connect mysql and Java

我正在尝试将Java代码连接到mySQL。 这是我得到的错误。 我不明白为什么没有找到驱动程序因为我把连接器jar放在类路径上。

Class Not Found Exception:
No suitable driver found for jdbc:mysql://localhost/hpdata?user=root&password=12
3456
Exception in thread "main" java.lang.NullPointerException
    at edu.indiana.iucbrf.feature.featurespec.FeatureSpecRDB.open(FeatureSpe
cRDB.java:122)
    at edu.indiana.iucbrf.feature.featurespec.FeatureSpecRDB.<init>(FeatureS
pecRDB.java:66)
    at edu.indiana.iucbrf.domain.componentfactory.RDBComponentFactory.constr
uctProblemFeatureSpecCollection(RDBComponentFactory.java:112)
    at edu.indiana.iucbrf.domain.Domain.<init>(Domain.java:239)
    at edu.indiana.iucbrf.domain.Domain.<init>(Domain.java:197)
    at edu.indiana.iucbrf.examples.honeypotRDBTemplate.HDomainRDB.<in
it>(HDomainRDB.java:56)
    at edu.indiana.iucbrf.examples.hRDBTemplate.HSystemRDB.set
 upDomain(HSystemRDB.java:198)
    at edu.indiana.iucbrf.examples.hRDBTemplate.HSystemRDB.<in
it>(HSystemRDB.java:131)
    at edu.indiana.iucbrf.examples.hRDBTemplate.HTestClassRDB.
main(HTestClassRDB.java:65)

这是我的代码:

   private static void flush() {

  Class.forName("com.mysql.jdbc.Driver").newInstance();

    try {

   conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/hpdata?user=root&password=123456");  

      } catch (Exception e) {
          System.out.println("Class Not Found Exception:");
          System.out.println(e.getMessage());       
      }
try {
 String driverName = "com.mysql.jdbc.Driver";
 Class.forName(driverName);

 String serverName = "localhost";
 String mydatabase = "hpdata";
 String url = "jdbc:mysql :// " + serverName + "/" + mydatabase; 

 String username = "root";
 String password = "123456";
 connection = DriverManager.getConnection(url, username, password);
} catch(Exception e) {
 // appropriate action
}

尝试通过合并此行来加载驱动程序。

Class.forName("com.mysql.jdbc.Driver")

确保mysql-connector-java-<version-number>-bin.jar在您的类路径中。 如果您没有,可以在此处下载

您假设您已正确设置CLASSPATH。 请解释一下你是怎么做的,这样我们就能告诉你它是否正确。

如果你设置了一个名为CLASSPATH的环境变量,那几乎肯定是错误的。

如果您的应用适用于网络或桌面,则会有所不同。 请告诉我们哪个是真的。

更新:

为桌面应用程序设置CLASSPATH的正确方法是在运行时在JVM上使用-classpath选项:

java -classpath .;<paths-to-your-JARs-separated-by-semi-colons>;<paths-to-the-root-of-package-trees> foo.YourCode

设置CLASSPATH请将mysql-connector-java-5.1.16-bin复制到这些文件夹中:

C:\Program Files\Java\jdk1.6.0_18\jre\lib\ext

C:\Program Files\Java\jre6\lib\ext

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM