如何使用 H2 内存数据库保存数据?

Posted

技术标签:

【中文标题】如何使用 H2 内存数据库保存数据?【英文标题】:How to save data using H2 in-memory database? 【发布时间】:2012-10-06 01:22:48 【问题描述】:

我正在做一个 grails 项目并尝试使用 H2 内存数据库来临时保存来自用户输入的数据。我在我的数据源中添加了这段代码:url = "jdbc:h2:memory" 来设置我的数据库。我创建了包含两个属性的域类。通过在浏览器中运行dbconsole,我可以浏览我创建的数据库和表(对应于类名)。我正在使用ClassName.save(flush:true) 将数据保存在内存数据库中,但这会引发错误'No property "database property name" of "class name" is found',当我在控制台中检查数据库时,什么都没有保存。

我错过了什么吗?请帮忙。

【问题讨论】:

请注意,默认情况下,当连接关闭时,内存数据库将被丢弃。您可以覆盖此行为。请参阅:Keep H2 in-memory database between connectionsH2 in-memory database. Table not found 【参考方案1】:

在我的项目中,配置字符串看起来不同:

dataSource 
    dbCreate = "create-drop" // one of 'create', 'create-drop', 'update', 'validate', ''
    url = "jdbc:h2:mem:devDb;MVCC=TRUE;LOCK_TIMEOUT=10000"

我相信,您有错误的“内存”并且您缺少数据库名称(“;”之前的 JDBC 字符串的最后一部分)。在此字符串下,您还可以通过“dbconsole”连接到数据库。

【讨论】:

以上是关于如何使用 H2 内存数据库保存数据?的主要内容,如果未能解决你的问题,请参考以下文章

如何使用hibernate jpa在内存数据库中设置h2?

具有弹簧安全性的 Grails 3.2.6。保存用户时未在内存中创建 h2 数据库

如何使用 H2 内存数据库编写单元测试

如何在内存数据库中使用 H2 测试 EntityManager 查询

使用 JPA 和 JUnit 测试时如何一致地擦除内存数据库中的 H2 [重复]

如何获取通过 H2DB 创建的“内存”数据库的流?