java.sql.SQLException: Не найдено подходящего драйвера для jdbc: derby: // localhost: 1527 / loginDB [duplicate]

Если вы не инициализировали ссылочный тип и хотите установить или прочитать одно из его свойств, он будет генерировать исключение NullReferenceException.

Пример:

Person p = null;
p.Name = "Harry"; // NullReferenceException occurs here.

Вы можно просто избежать этого, проверив, является ли переменная не нулевой:

Person p = null;
if (p!=null)
{
    p.Name = "Harry"; // Not going to run to this point
}

Чтобы полностью понять, почему выбрано исключение NullReferenceException, важно знать разницу между типами значений и ссылочные типы .

Итак, если вы имеете дело со типами значений, NullReferenceExceptions не может произойти. Хотя вам нужно поддерживать оповещение при работе со ссылочными типами!

Только ссылочные типы, как следует из названия, могут содержать ссылки или буквально буквально ничто (или «нуль»). Если типы значений всегда содержат значение.

Типы ссылок (эти должны быть проверены):

  • динамический
  • объект
  • string

Типы значений (вы можете просто игнорировать эти):

  • Числовые типы
  • Интегральные типы
  • Типы с плавающей запятой
  • decimal
  • bool
  • Пользовательские структуры

22
задан BalusC 28 September 2010 в 19:51
поделиться

16 ответов

Возможно, вам не удастся запустить сервер Derby. После запуска сервера дерби он начинает прослушивать порт по умолчанию 1527.

Стартовый скрипт расположен ниже:

Windows:

    <DERBY_INSTALLATION_DIRECTORY>/bin/startNetworkServer.bat

Linux:

    <DERBY_INSTALLATION_DIRECTORY>/bin/startNetworkServer
1
ответ дан Amit Kaneria 27 August 2018 в 19:33
поделиться

JDBC DriverManager не может найти подходящий Driver для данного URL соединения. Перед подключением БД драйвер JDBC вообще не загружается, или URL-адрес подключения неверен. Поскольку URL-адрес подключения выглядит нормально, я уверен, что драйвер вообще не загружен. Перед подключением БД вам необходимо загрузить драйвер во время запуска приложения. Для Apache Derby имя класса драйвера - org.apache.derby.jdbc.ClientDriver. Итак:

Class.forName("org.apache.derby.jdbc.ClientDriver");
4
ответ дан BalusC 27 August 2018 в 19:33
поделиться

Для меня

DriverManager.registerDriver(new org.apache.derby.jdbc.EmbeddedDriver());

помог. Таким образом, DriveManager знает дерби EmbeddedDriver. Возможно, выделение нового EmbeddedDriver является тяжелым, но с другой стороны, Class.forName нуждается в try / catch / doSomethingIntelligentWithException, которое мне не очень нравится.

10
ответ дан Bruno Eberhard 27 August 2018 в 19:33
поделиться

Также возможно, что в файле persistence.xml использовался EmbeddedDriver, в то время как URL-адрес jdbc указывал на сервер Derby. В этом случае просто измените url на указание пути к базе данных.

0
ответ дан chance 27 August 2018 в 19:33
поделиться

У меня была такая же проблема, когда я писал приложение Java на Netbeans.Here это решение:

  1. Найти свой проект на вкладке выбора проектов
  2. Щелкните правой кнопкой мыши «Библиотеки
  3. Нажмите «Добавить JAR / Папка ...»
  4. Выберите «derbyclient.jar»
  5. Нажмите «Открыть», после чего вы увидите «derbyclient. jar "под вашими" Библиотеками "
  6. Убедитесь, что ваш URL, имя пользователя, слово передано правильно и запустите свой код:)
3
ответ дан CounterSpell 27 August 2018 в 19:33
поделиться

, если база данных создана и вы начали соединение с ней, тогда вам нужно добавить банку драйвера. из окна проекта щелкните правой кнопкой мыши папку библиотек, перейдите в: programfiles \ sun \ javadb \ lib \ derbyclient.jar. загрузите файл, и вы сможете его запустить.

все лучшее

0
ответ дан csejay 27 August 2018 в 19:33
поделиться

Я попробовал все, что упоминалось в этой теме, и только .registerDriver () работал для меня. Вот как выглядит моя часть кода:

DriverManager.registerDriver(new org.apache.derby.jdbc.ClientDriver());
connection = DriverManager.getConnection(url, user, pass);

Обратите внимание, что проблема не во встроенном Derby.

0
ответ дан dafilipaj 27 August 2018 в 19:33
поделиться

Я столкнулся с подобной проблемой, и она была решена, включив в eclipse файлы derby.jar, derbyclient.jar, derbynet.jar и derbytools.jar в вашем пути к классам.

Выполните шаги -

  1. Щелкните правой кнопкой мыши на своем проекте и выберите «Путь сборки» -> «Настроить путь сборки».
  2. Перейдите на вкладку «Библиотеки» и нажмите «Добавить внешние JAR».
  3. Выберите выше банки из пути, например C: \ Program Files \ Java \ jdk1.8.0_161 \ db \ lib
  4. Нажмите OK.

Надеюсь, что это поможет:)

0
ответ дан Hetal Rachh 27 August 2018 в 19:33
поделиться

Я решил это, добавив библиотеку в библиотечную консоль ниже моего проекта:

  • Щелкните правой кнопкой мыши, а затем добавьте библиотеку
  • , добавьте JAVA DB DRIVER.

Мой проект работает!

2
ответ дан Iain Ballard 27 August 2018 в 19:33
поделиться

Если вы используете встроенное Derby, вам нужно Derby.jar в вашем пути к классам.

2
ответ дан James McMahon 27 August 2018 в 19:33
поделиться

Ответ на этот вопрос дан, но для иллюстрации показана командная строка. Это работало для меня, когда я пытался как можно более простой тест подключиться к сетевому дерби.

  • Драйвер, загруженный в приложение с помощью: Class.forName ("org.apache.derby.jdbc. ClientDriver "). NewInstance ();
  • URL-адрес подключения:« jdbc: derby: // localhost: 1527 / myDB; create = true »
  • Я запустил приложение, используя: java -classpath derbyclient.jar :. myAppClass
2
ответ дан lemic 27 August 2018 в 19:33
поделиться

Обратите внимание: вы можете скачать его из здесь .

Если вы не можете его найти, то

  1. Найдите свой проект в проектах вкладка выбора
  2. Щелкните правой кнопкой мыши «Библиотеки»
  3. Нажмите «Добавить JAR / Папка ...»
  4. Выберите «derbyclient.jar»
  5. Нажмите «Открыть», затем вы увидите «derbyclient.jar» в разделе «Библиотеки»

Убедитесь, что ваш URL, имя пользователя, пароль верны и запустите свой код:)

15
ответ дан Marko 27 August 2018 в 19:33
поделиться

Эта ошибка возникает, когда синтаксис строки подключения недопустим.

Вы можете использовать строку подключения как

'jdbc:derby:MyDbTest;create=true'

или

, вы можете используйте следующую команду в командной строке, команда ниже создает новую базу данных с именем MyDbTest успешно:

connect 'jdbc:derby:MyDbTest;create=true';
0
ответ дан n4m31ess_c0d3r 27 August 2018 в 19:33
поделиться

Вы также можете получить ту же ошибку, если сервер Java DB не был запущен.

0
ответ дан ntombela 27 August 2018 в 19:33
поделиться

java.sql.SQLException: Не найдено подходящего драйвера для jdbc: derby: // localhost: 1527 /

Это исключение имеет две причины:

  • Драйвер не загружен.
  • URL-адрес JDBC неверен.

В вашем случае я ожидаю увидеть имя базы данных в конце строки подключения. Например (используйте create=true, если вы хотите, чтобы база данных была создана, если она не существует):

jdbc:derby://localhost:1527/dbname;create=true

Базы данных создаются по умолчанию в каталоге, где был запущен Сетевой сервер. Но вы также можете указать абсолютный путь к местоположению базы данных:

jdbc:derby://localhost:1527//home/pascal/derbyDBs/dbname;create=true

И на всякий случай убедитесь, что derbyclient.jar находится в пути к классу и что вы загружаете соответствующий драйвер org.apache.derby.jdbc.ClientDriver, когда работающих в режиме сервера.

22
ответ дан Pascal Thivent 27 August 2018 в 19:33
поделиться

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

<groupId>org.apache.derby</groupId>
<artifactId>derbyclient</artifactId>
<version>10.10.1.1</version>

. Будьте осторожны с версия. Он должен быть совместим с экземпляром сервера, в котором вы работаете.

Я решил свой случай, отказавшись от каких-либо зависимостей maven и вручную добавив внешнюю банку из «% JAVA_HOME% \ db \ lib», тот же источник моего работающего сервера. В этом случае я тестирую, используя мой Local.

Итак, если вы тестируете экземпляр удаленного сервера, найдите файл derbyclient.jar, который поставляется с серверным пакетом.

0
ответ дан peterong 27 August 2018 в 19:33
поделиться
Другие вопросы по тегам:

Похожие вопросы: