Если вы не инициализировали ссылочный тип и хотите установить или прочитать одно из его свойств, он будет генерировать исключение 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 не может произойти. Хотя вам нужно поддерживать оповещение при работе со ссылочными типами!
Только ссылочные типы, как следует из названия, могут содержать ссылки или буквально буквально ничто (или «нуль»). Если типы значений всегда содержат значение.
Типы ссылок (эти должны быть проверены):
Типы значений (вы можете просто игнорировать эти):
Возможно, вам не удастся запустить сервер Derby. После запуска сервера дерби он начинает прослушивать порт по умолчанию 1527.
Стартовый скрипт расположен ниже:
Windows:
<DERBY_INSTALLATION_DIRECTORY>/bin/startNetworkServer.bat
Linux:
<DERBY_INSTALLATION_DIRECTORY>/bin/startNetworkServer
JDBC DriverManager
не может найти подходящий Driver
для данного URL соединения. Перед подключением БД драйвер JDBC вообще не загружается, или URL-адрес подключения неверен. Поскольку URL-адрес подключения выглядит нормально, я уверен, что драйвер вообще не загружен. Перед подключением БД вам необходимо загрузить драйвер во время запуска приложения. Для Apache Derby имя класса драйвера - org.apache.derby.jdbc.ClientDriver
. Итак:
Class.forName("org.apache.derby.jdbc.ClientDriver");
Для меня
DriverManager.registerDriver(new org.apache.derby.jdbc.EmbeddedDriver());
помог. Таким образом, DriveManager знает дерби EmbeddedDriver. Возможно, выделение нового EmbeddedDriver является тяжелым, но с другой стороны, Class.forName нуждается в try / catch / doSomethingIntelligentWithException, которое мне не очень нравится.
Также возможно, что в файле persistence.xml использовался EmbeddedDriver, в то время как URL-адрес jdbc указывал на сервер Derby. В этом случае просто измените url на указание пути к базе данных.
У меня была такая же проблема, когда я писал приложение Java на Netbeans.Here это решение:
, если база данных создана и вы начали соединение с ней, тогда вам нужно добавить банку драйвера. из окна проекта щелкните правой кнопкой мыши папку библиотек, перейдите в: programfiles \ sun \ javadb \ lib \ derbyclient.jar. загрузите файл, и вы сможете его запустить.
все лучшее
Я попробовал все, что упоминалось в этой теме, и только .registerDriver () работал для меня. Вот как выглядит моя часть кода:
DriverManager.registerDriver(new org.apache.derby.jdbc.ClientDriver());
connection = DriverManager.getConnection(url, user, pass);
Обратите внимание, что проблема не во встроенном Derby.
Я столкнулся с подобной проблемой, и она была решена, включив в eclipse файлы derby.jar, derbyclient.jar, derbynet.jar и derbytools.jar в вашем пути к классам.
Выполните шаги -
Надеюсь, что это поможет:)
Я решил это, добавив библиотеку в библиотечную консоль ниже моего проекта:
Мой проект работает!
Если вы используете встроенное Derby, вам нужно Derby.jar в вашем пути к классам.
Ответ на этот вопрос дан, но для иллюстрации показана командная строка. Это работало для меня, когда я пытался как можно более простой тест подключиться к сетевому дерби.
Обратите внимание: вы можете скачать его из здесь .
Если вы не можете его найти, то
Убедитесь, что ваш URL, имя пользователя, пароль верны и запустите свой код:)
Эта ошибка возникает, когда синтаксис строки подключения недопустим.
Вы можете использовать строку подключения как
'jdbc:derby:MyDbTest;create=true'
или
, вы можете используйте следующую команду в командной строке, команда ниже создает новую базу данных с именем MyDbTest
успешно:
connect 'jdbc:derby:MyDbTest;create=true';
Вы также можете получить ту же ошибку, если сервер Java DB не был запущен.
java.sql.SQLException: Не найдено подходящего драйвера для jdbc: derby: // localhost: 1527 /
blockquote>Это исключение имеет две причины:
- Драйвер не загружен.
- 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
, когда работающих в режиме сервера.
Я просто столкнулся с этой проблемой, попробовал все вышеприведенные предложения, но все еще не смог. Без повторения того, что было предложено выше, вот что я могу вам сказать: если вы используете maven, вероятно, вы укажете зависимости, например:
<groupId>org.apache.derby</groupId>
<artifactId>derbyclient</artifactId>
<version>10.10.1.1</version>
. Будьте осторожны с версия. Он должен быть совместим с экземпляром сервера, в котором вы работаете.
Я решил свой случай, отказавшись от каких-либо зависимостей maven и вручную добавив внешнюю банку из «% JAVA_HOME% \ db \ lib», тот же источник моего работающего сервера. В этом случае я тестирую, используя мой Local.
Итак, если вы тестируете экземпляр удаленного сервера, найдите файл derbyclient.jar, который поставляется с серверным пакетом.