我正在开发一个grails项目,并尝试使用H2内存数据库暂时保存来自用户输入的数据。我在我的数据源中添加了这段代码:url = "jdbc:h2:memory"
来设置我的数据库。我创建了包含两个属性的Domain Class。通过在浏览器中运行dbconsole
,我可以浏览我创建的数据库和表(对应于类名)。我使用ClassName.save(flush:true)
将数据保存在内存数据库中,但这会引发错误'No property "database property name" of "class name" is found'
,当我在控制台中检查数据库时,没有保存任何内容。
我错过了什么吗?请帮忙。
答案 0 :(得分:2)
在我的项目中,配置字符串看起来不同:
dataSource {
dbCreate = "create-drop" // one of 'create', 'create-drop', 'update', 'validate', ''
url = "jdbc:h2:mem:devDb;MVCC=TRUE;LOCK_TIMEOUT=10000"
}
我相信,你错了“内存”并且你错过了数据库名称(在“;”之前的JDBC字符串的最后一部分)。在此字符串下,您还可以通过“dbconsole”连接到数据库。