H2内存数据库。找不到表格

我有一个带有URL的H2数据库"jdbc:h2:test"。我使用创建表格CREATE TABLE PERSON (ID INT PRIMARY KEY, FIRSTNAME VARCHAR(64), LASTNAME VARCHAR(64));。然后,我使用从(空)表中选择所有内容SELECT * FROM PERSON。到现在为止还挺好。

但是,如果将URL更改为"jdbc:h2:mem:test",唯一的区别是数据库现在仅在内存中,这给了我一个org.h2.jdbc.JdbcSQLException: Table "PERSON" not found; SQL statement: SELECT * FROM PERSON [42102-154]。我可能在这里缺少一些简单的东西,但是任何帮助将不胜感激。


Cats萌萌
浏览 2021回答 3
3回答

白衣染霜花

hbm2ddl在创建表后关闭连接,因此h2放弃该连接。如果您的连接网址是这样配置的jdbc:h2:mem:test在最后一个连接关闭时,数据库的内容会丢失。如果要保留内容,则必须像这样配置网址jdbc:h2:mem:test;DB_CLOSE_DELAY=-1如果这样做,h2将保留其内容,直到虚拟机存活。

慕哥6287543

我知道这不是您的情况,但我遇到了同样的问题,因为即使我在所有脚本(包括创建脚本)中都使用小写字母,H2都使用大写名称创建表,然后区分大小写。通过添加;DATABASE_TO_UPPER=false到连接URL来解决。
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Java