Прежде всего, я хотел бы сказать, что я новичок в базе данных h2. Мне нужно выполнить файл сценария sql в базе данных h2. У меня есть файл сценария test.sql, и я хочу выполнить его в базе данных h2. Является ли это возможным?Выполнение файла сценария в базе данных h2
ответ
Вы можете использовать RUNSCRIPT SQL statement:
RUNSCRIPT FROM 'test.sql'
или вы можете использовать RunScript standalone/command line tool:
java -cp h2*.jar org.h2.tools.RunScript -url jdbc:h2:~/test -script test.sql
Вы также можете использовать инструмент RunScript внутри приложения:
RunScript.execute(conn, new FileReader("test.sql"));
Для мне ответила система:
не нашел драйвера org.h2.tools.RunScript
Решение было:
java -classpath <path_to_your_h2-*.jar> org.h2.tools.RunScript \
-url jdbc:h2:tcp://localhost/~/test -script test.sql
См: http://www.h2database.com/html/tutorial.html#using_server
На OSX (это не должно действительно имеет значение) с v. 1.4.192 со следующими командами, независимо от того, что я сделал, я не видел никаких результатов:
java -cp h2*.jar org.h2.tools.RunScript -url "jdbc:h2:file:~/testdb" -user someusername -password somepass -script select.sql
где select.sql было просто:
select * from PUBLIC.MYTABLE;
мне пришлось добавить -showResults
перед выводом начала появляться. Вот полная команда:
java -cp /Users/az/.m2/repository/com/h2database/h2/1.4.192/h2-1.4.192.jar org.h2.tools.RunScript -url "jdbc:h2:file:~/testdb" -user someusername -password somepass -script select.sql -showResults
Если у вас нет необходимого банку, скачать с here (Нажмите на jar
ссылок рядом с каждой версией). Некоторые прямые ссылки на банки следующим образом:
1.4.193(Обновлено 31-Октябрь-2016)
1.4.192(Updated 26-May-2016)
1.4.191(Обновлено 21-январе- 2016)
1.4.190(Обновлено 11-Октябрь-2016)
- 1. Загрузка базы данных H2 из сценария
- 2. Слияние в базе данных H2
- 3. Как подключиться к базе данных H2 из Java & H2 DB
- 4. Нечеткое соответствие в базе данных H2?
- 5. Функция TO_CHAR недоступна в базе данных H2
- 6. идентификатор автоинкремента в базе данных H2
- 7. SELECT * WHERE в базе данных H2
- 8. Сравнить битмаски в базе данных H2
- 9. Отключить анонимный пользователь в базе данных h2
- 10. B + Дерево в базе данных H2
- 11. Выполнение сценария узла изнутри файла
- 12. Выполнение сценария оболочки из файла
- 13. Запятые в базе данных сценария
- 14. Как использовать команду DESC в базе данных H2?
- 15. Выполнение изменений в базе данных
- 16. Выполнение сопоставления в базе данных
- 17. PHP подключение к базе данных H2DB H2
- 18. Подключение к базе данных h2 с Glassfish
- 19. Создать представление о базе данных h2
- 20. H2 повреждение базы данных
- 21. Как получить тип данных конкретного столбца в базе данных H2
- 22. Выполнение сценария сценария
- 23. Запросы Sql не выполняются в базе данных H2
- 24. Имеющиеся проблемы в базе данных H2 могут быть уже использованы
- 25. Выполнение пакетного сценария
- 26. Вставка длинного текста в базу данных H2 из сценария SQL
- 27. Как подключиться к базе данных режима WebServer H2 в консоли?
- 28. Выполнение полнотекстового поиска в базе данных H2 с использованием JPA (Eclipselink)
- 29. Выполнение командного файла с использованием сценария Python
- 30. Выполнение SQL-файла из сценария BAT
Есть ли уловка для использования вашего первого примера? У меня есть 'bootstrap.sql', который содержит ничего, кроме' RUNSCRIPT FROM 'test.sql'', а мой test.sql является братом для файла начальной загрузки. Если я запускаю 'jdbc: h2: mem: etsnom; INIT = RUNSCRIPT FROM 'C:/workspace/bootstrap.sql'', я получаю' FileNotFoundException' – Snekse
Если мы используем второй метод Томаса для создания базы данных, тогда имя пользователя и пароль по умолчанию будут установлены, т.е. "" [пустая строка]. это то, что реализовано в классе «RunScript». Однако всегда очень важно установить имя пользователя и пароль для доступа к базе данных и сделать это в случае базы данных H2, мы можем выполнить команду ниже: java -cp h2 *.jar org.h2.tools.RunScript -url jdbc: h2: ~/test -user sa -password sa -script test.sql –