【问题标题】:MS ACCESS jdbc.odbc connection. data source name not found/No default driver specified?MS ACCESS jdbc.odbc 连接。未找到数据源名称/未指定默认驱动程序?
【发布时间】:2012-05-10 06:26:53
【问题描述】:

我正在尝试在学校学习基本 SQL 测试,但不幸的是,我将我们应该使用的课程复制到我的电脑上的项目中,我收到以下错误:

java.sql.SQLException: [Microsoft][ODBC Driver Manager] 未找到数据源名称且未指定默认驱动程序

package Question1;

// Your name, Q 1
import java.sql.*;
import java.io.*;
import javax.swing.*;

public class GreenWood
{
 // Set up database connection
   private static final String DATABASE_FILE_NAME = "WoodDB.mdb";
   private static final String DRIVER = "jdbc:odbc:DRIVER=" +
   "{Microsoft Access Driver (*.mdb)};" +
   "DBQ=" + new File (DATABASE_FILE_NAME).getAbsolutePath ();
  static
  {
     try
     {
        Class.forName ("sun.jdbc.odbc.JdbcOdbcDriver");
     }
         catch (ClassNotFoundException e)
        {
           System.out.println ("Class not found");
           e.printStackTrace ();
        }
  }


  private Connection dbcon;
  private BufferedReader keyb = new BufferedReader (new InputStreamReader (System.in));

   public GreenWood ()
  {
     System.out.println ("WoodDB Connection");
     try
     {
        dbcon = DriverManager.getConnection (DRIVER);
        Statement stmt = dbcon.createStatement ();
        System.out.println ("Connection successful\n");

        char choice = ' ';
        do
        {

         //Prints options for user input

           choice = keyb.readLine ().toUpperCase ().charAt (0);
           System.out.println (" ");
           switch (choice)
           {
             //calls query methods based on user input

           }
        }
        while (choice != 'X');
        dbcon.close ();
        System.out.println ("Done");
        Thread.sleep (1000);
        System.exit (0);
     } // try
         catch (Exception e)
        {
        // process exceptions here
           System.out.println ("Connection unsuccessful");
           e.printStackTrace ();
           System.out.println (e.toString ());
        }
  } // HoutSoorte constructor

  //Query Methods
  //Main creates new instance of GreenWood

我的 WoodDB 数据库位于项目根目录中。

我已经做了一些故障排除,我认为问题在于驱动程序位置的 URL;

dbcon = DriverManager.getConnection (DRIVER);

司机是:

private static final String DRIVER = "jdbc:odbc:DRIVER=" +
   "{Microsoft Access Driver (*.mdb)};" +
   "DBQ=" + new File (DATABASE_FILE_NAME).getAbsolutePath ();

经过大约一个小时的研究,我仍然和以前一样困惑。 如果有人可以通过用简单的语言解释问题以及我如何解决它来帮助这个小程序程序员(我),那将不胜感激。

【问题讨论】:

  • 不要忘记在作业问题中添加 [tag:homework' 标签!我敢打赌,它的追随者比“ms​​-access-2000”或我添加标签的任何东西都要多。
  • “我将我们应该使用的类复制到我的电脑上的项目中” 你是否也复制了数据库和数据库驱动程序?通常,驱动程序将位于必须添加到应用程序的运行时类路径的 Jar 中。
  • 感谢安德鲁的回复。我相信JDK中默认包含JDBC/ODBC驱动。

标签: java sql database jdbc-odbc


【解决方案1】:

如果可行,请尝试以下操作:

对于 64 位系统,转到:C:\windows\sysWOW64。 对于 32 位系统,转到:C:\windows

有一个名为 odbcad32.exe 的可执行文件。

以管理员身份运行此 exe 以获得对 Microsoft Office 等附带的所有 ODBC 驱动程序的访问权限。

创建名为 my_data_source 的数据源,并将连接字符串记为:

Connection con = DriverManager.getConnection("jdbc:odbc:my_data_source");

以上解决方案适用于我的情况。

请参考:Java Connectivity with MS Access 了解详情。

【讨论】:

    【解决方案2】:

    尝试使用 32 位 JVM。尝试从 64 位 JVM 连接时收到相同的错误消息。

    【讨论】:

    • 它有效!谢谢!正如我之前对 Andrew 所说,odbc 默认包含在 JDK 中,但只有 32 位版本。更改 jvm 不是一个很好的(或永久的)解决方案,但据说 ODBC 已经过时,除非完全必要,否则不应使用。(比如不幸的学生)
    • 我最近询问如何解决这个问题,但还没有时间尝试建议的解决方案。无论如何,如果你有兴趣看看:stackoverflow.com/questions/10289655/….
    【解决方案3】:

    尝试使用 DATABASE_FILE 的完整路径名或将其复制到源目录。

    【讨论】:

    • 使用 file.getAbsolutePath() 实现的不是同样的事情; ?
    • 可能不行,File对象应该能先找到文件,然后getAbsolutePath()才能工作。
    猜你喜欢
    • 1970-01-01
    • 2013-04-15
    • 1970-01-01
    • 2014-12-05
    • 2013-04-23
    • 1970-01-01
    相关资源
    最近更新 更多