Форум программистов, компьютерный форум, киберфорум
Java: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.70/23: Рейтинг темы: голосов - 23, средняя оценка - 4.70
0 / 0 / 0
Регистрация: 20.09.2011
Сообщений: 3

База данных InterBase и Java

22.03.2012, 18:14. Показов 4336. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Надо подконнектиться к InterBase 6.5 c помощью Java.
Написал следующее:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
import java.*;
import java.sql.*;
 
public class dbaccess {
    public static void main(String[] args) {
        String url = "jdbc:interbase";
        String Driver_Name = "interbase.interclient.Driver";
        String location = "//localhost/d:/Verl/temp.gdb";
        String user = "SYSDBA";
        String pswd = "masterkey";
        String query = "SELECT * FROM book";
        // load driver
        try
        {
           Class.forName("interbase.interclient.Driver");
           Connection con = DriverManager.getConnection(url+location,user,pswd);
           System.out.println("Connection attempted");
           con.close();
        }
        catch (Exception e)
        {
           System.out.println("Miss database connection");
           e.printStackTrace();
           System.exit(1);
        }
    }
}
При запуске (JDK 1.5, JBuilder2006) выдает
Exception in thread "main" java.lang.NoClassDefFoundError: dbaccess
Есть подозрение что
1) неправильно подключаю драйвер:
В переменную среды CLASSPATH поместил значение [italic]D:BorlandJBuilder2006 hirdpartyInterClient[/italic]
и загружаю его из программы Class.forName("interbase.interclient.Dri ver");

2) Драйвер не подходит к БД - в документации сообщается что поддерживается InterBase 7. Также на эту мысль наводит тот факт, что утилита Database Pilot не может получить доступ к базе данных и выдает следующее
Code
1
interbase.interclient.IBException: [interclient][interbase]connection rejected by remote interface
Stack Trace :
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
See com.borland.dx.dataset.DataSetException error code:  BASE+66
com.borland.dx.dataset.DataSetException: interbase.interclient.IBException: [interclient][interbase]connection rejected by remote interface
    at com.borland.dx.dataset.DataSetException.a(Unknown Source)
    at com.borland.dx.dataset.DataSetException.throwException(Unknown Source)
    at com.borland.dx.dataset.DataSetException.SQLException(Unknown Source)
    at com.borland.dx.sql.dataset.Database.openConnection(Unknown Source)
    at com.borland.jdbcx.metadata.DatabaseInfo.openConnection(Unknown Source)
    at com.borland.jdbcx.metadata.d.run(Unknown Source)
Chained exception:
java.sql.SQLException: interbase.interclient.IBException: [interclient][interbase]connection rejected by remote interface
    at interbase.interclient.Connection.remote_ATTACH_DATABASE(Unknown Source)
    at interbase.interclient.Connection.connect(Unknown Source)
    at interbase.interclient.Connection.<init>(Unknown Source)
    at interbase.interclient.Driver.connect(Unknown Source)
    at java.sql.DriverManager.getConnection(DriverManager.java:525)
    at java.sql.DriverManager.getConnection(DriverManager.java:171)
    at com.borland.dx.sql.dataset.Database.openConnection(Unknown Source)
    at com.borland.jdbcx.metadata.DatabaseInfo.openConnection(Unknown Source)
    at com.borland.jdbcx.metadata.d.run(Unknown Source)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
22.03.2012, 18:14
Ответы с готовыми решениями:

База данных и JAVA?
У меня главный вопрос , где скачать этот драйвер , на сайте у Сан есть несколько драйверов но к ним нет примеров, раньше у меня стоял...

Java база данных
кто может объяснить как использовать базу данных sql в программе на языке Java, какие программы и драйвера нужно поставить?

База данных на Java
Я плохо разбираюсь в базах данных,так что прошу Вас помочь мне.Мне надо создать базу данных через JDBC-ODBC. вот так я подключаю драйвер...

8
1 / 1 / 3
Регистрация: 03.08.2008
Сообщений: 390
22.03.2012, 19:50
Попробуй заюзать не interclient а абычный драйвер
0
1 / 1 / 3
Регистрация: 03.08.2008
Сообщений: 390
22.03.2012, 19:51
Может лучше пересесть на Firebird
0
mishgun
23.03.2012, 02:24
в CLASSPATH надо подключать jar или zip с драйвером а не директорию где он лежит
0 / 0 / 0
Регистрация: 20.09.2011
Сообщений: 3
24.03.2012, 01:54  [ТС]
[bold]2ogapon[/bold]
1) А обычный драйвер это какой? ODBC?
2) На Firebird рад бы, да не от меня зависит

[bold]2mishgun[/bold]
Лично отследил чтобы в Classpath был interclient.
Для MySQL все работает как часы.

Вообщем насколько я понял после выдачи следующего сообщения:
Code
1
2
3
4
5
6
7
8
java.sql.SQLException: interbase.interclient.IBException: [interclient][interbase]connection rejected by remote interface
    at interbase.interclient.Connection.remote_ATTACH_DATABASE(Unknown Source)
    at interbase.interclient.Connection.connect(Unknown Source)
    at interbase.interclient.Connection.<init>(Unknown Source)
    at interbase.interclient.Driver.connect(Unknown Source)
    at java.sql.DriverManager.getConnection(DriverManager.java:525)
    at java.sql.DriverManager.getConnection(DriverManager.java:171)
    at testDBaccess.main(testDBaccess.java:28)
Происходит конфликт версий драйвера и СУБД. Наверное для Interbase 6.5
требуется старый драйвер 3-го типа.
0
0 / 0 / 1
Регистрация: 21.03.2012
Сообщений: 13
25.03.2012, 09:09
При запуске (JDK 1.5, JBuilder2006) выдает
Exception in thread "main" java.lang.NoClassDefFoundError: dbaccess

Вот это сообщение относится к твоему классу, листинг которого ты здесь привел, от ведь именно так и называется.
0
0 / 0 / 0
Регистрация: 20.09.2011
Сообщений: 3
25.03.2012, 12:46  [ТС]
Привожу немного исправленный код
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
import java.sql.*;
 
public class tesDBaccess {
   public static void main(String[] args) {
        // vars
        String drvr = "interbase.interclient.Driver";
        String url = "jdbc:interbase://localhost/D:/Verl/TEMP.GDB";
        String user = "sysdba";
        String pswd = "masterkey";
 
        //load driver
        System.out.print("Loading driver to Database ..."); 
        try {
            Class.forName(drvr);
            System.out.println("successfully.");
        } catch (Exception ex) {
            System.out.println("failed.");
            ex.printStackTrace();
        }
        // Connecting to database
        System.out.print("Connecting to database ...");
        Connection con;
        try {
            con = DriverManager.getConnection(url,user,pswd);
            System.out.println("successfully.");
            con.close();
        } catch (Exception ex) {
            System.out.println("failed.");
            ex.printStackTrace();
        }
    }
}
Выводит следующее
Кликните здесь для просмотра всего текста
Loading driver to Database ...successfully.
Connecting to database ...java.sql.SQLException: interbase.interclient.IBException: [interclient][interbase]connection rejected by remote interface
at interbase.interclient.Connection.remote_ ATTACH_DATABASE(Unknown Source)
at interbase.interclient.Connection.connect (Unknown Source)
at interbase.interclient.Connection.<init>( Unknown Source)
failed.
at interbase.interclient.Driver.connect(Unk nown Source)
at java.sql.DriverManager.getConnection(Dri verManager.java:525)
at java.sql.DriverManager.getConnection(Dri verManager.java:171)
at tesDBaccess.main(tesDBaccess.java:36)
Отсюда видно что драйвер загружается, но соединение не происходит из-за удаленного интерфейса. Плюс смущает то, что появляется "Unknown Source".
0
Valers
27.03.2012, 20:04
Попробуй мост JDBC-ODBC
jdbc:odbc:<data-source-name>[;<attribute-name>=<attribute-value>]*

Статейка о подключении FireBird.
http://www.linuxcenter.ru/lib/articles/programming/jbird.phtml
0 / 0 / 1
Регистрация: 21.03.2012
Сообщений: 13
28.03.2012, 09:20
"Unknown Source" означает, что Java не может учазать конкретное место в исходном коде (*.java файл) класса interbase.interclient.Connection. Почему это происходит точно не помню, толи такая информация не содержится в байт-коде поскольку *.class файл был скомпилирован со специальными ключами в целях оптимизации быстродействия, толи не доступен *.java файл. Но такое встречается нередко, поставляемыми без исходников.
По сути проблемы к сожалению могу только предположить, что база данных не дает тебе доступа, может быть user или pswd неправильные.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
28.03.2012, 09:20
Помогаю со студенческими работами здесь

Java, ApachePOI и база данных
У меня есть проект, работающий с базой данных. Данные импортируются из таблицы EXCEL и анализируются с помощью запросов как в базе данных....

База данных "Книжный магазин" в interbase
Создать базу данных в interbase автоматизация книжного магазина.

Java и локальная база данных
Есть возможность включить в jar файл локальную базу данных? Что это за базы? Чтобы вообщем без сервера.

Небольшая база данных в java
подскажите пожалуйста с кодом реализации. Итак предположим у нас есть два человека. У этих людей имя фамилия и адрес. Нужно сделать поиск...

База данных под java и android
Может кто подскажет. Вообщем надо сделать базу данных, к которой будет доступ с программы на java на компе и с телефона на android....


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru