Соединение MS ACCESS jdbc.odbc. имя источника данных не найдено/не указан драйвер по умолчанию?

Я пытаюсь подготовиться к базовому тесту SQL в школе, но, к сожалению, я скопировал класс, который мы должны использовать, в проект на своем компьютере, и я получаю следующую ошибку:

java.sql.SQLException: [Microsoft] [Диспетчер драйверов ODBC] Имя источника данных не найдено, и драйвер по умолчанию не указан

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 ();

Примерно через час исследований я все еще в таком же замешательстве, как и раньше. Если кто-нибудь может помочь этому нуб-программисту (мне), объяснив проблему детскими словами и то, как я могу ее исправить, я всегда буду признателен.


person Ross Borchers    schedule 30.04.2012    source источник
comment
Не забудьте добавить тег [tag:homework' к домашним заданиям! Бьюсь об заклад, у него гораздо больше подписчиков, чем у «ms-access-2000» или чего-то еще, что я добавил, чтобы добавить тег.   -  person Andrew Thompson    schedule 30.04.2012
comment
Я скопировал класс, который мы должны использовать, в проект на моем компьютере Вы также скопировали БД и драйвер БД? Обычно драйвер находится в банке, которую необходимо добавить в путь к классам во время выполнения приложения.   -  person Andrew Thompson    schedule 30.04.2012
comment
Спасибо за ответ Андрей. Я считаю, что драйвер JDBC/ODBC включен в JDK по умолчанию.   -  person Ross Borchers    schedule 30.04.2012


Ответы (3)


Попробуйте использовать 32-битную JVM. Я получаю такое же сообщение об ошибке при попытке подключения с 64-битной JVM.

person Pedro    schedule 30.04.2012
comment
Оно работает! Благодарность! как я уже говорил Эндрю ранее, odbc включен в JDK по умолчанию, но есть только 32-битная версия. изменение jvm не является отличным (или постоянным) решением, но якобы ODBC устарел и не должен использоваться без крайней необходимости (как в случае с несчастным школьником). - person Ross Borchers; 30.04.2012
comment
Недавно я спросил, как решить эту проблему, но еще не успел попробовать предложенное решение. В любом случае, если вам интересно, посмотрите: stackoverflow.com/questions/10289655/. - person Pedro; 30.04.2012

Попробуйте следующее, если это работает:

Для 64-битной системы перейдите в папку C:\windows\sysWOW64. Для 32-битной системы перейдите к: C:\windows

Существует исполняемый файл odbcad32.exe.

Запустите этот exe-файл от имени администратора, чтобы получить доступ ко всем драйверам ODBC, поставляемым с Microsoft Office и т. д.

Создайте источник данных с именем my_data_source и укажите строку подключения как:

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

Вышеупомянутое решение сработало в моем случае.

Дополнительные сведения см. в разделе Java Connectivity with MS Access.

person coder    schedule 29.06.2013

попробуйте использовать полный путь к DATABASE_FILE или скопируйте его в исходный каталог.

person user1335794    schedule 30.04.2012
comment
Разве не то же самое достигается использованием file.getAbsolutePath(); ? - person Ross Borchers; 30.04.2012
comment
вероятно, нет, объект File должен сначала найти файл, затем getAbsolutePath() может работать. - person user1335794; 30.04.2012