我试图在本指南的帮助下在 grails 控制台中创建一个新的域对象。根据控制台输出创建新对象:
grails> shell
groovy:000> new foo.Book(title: 'bar').save(failOnError: true, flush: true)
groovy:000> foo.Book : 1
groovy:000> foo.Book.list()
groovy:000> [foo.Book : 1]
但是这个新书实体在 dbconsole 中不可见当我使用 DataSource.groovy 中找到的开发环境的 JDBC url 连接时,表 BOOK 存在:
jdbc:h2:mem:devDb;MVCC=TRUE
username: sa
password: <blank>
但选择返回 0 行
相关的 DataSource.groovy 配置(默认)
dataSource {
pooled = true
driverClassName = "org.h2.Driver"
username = "sa"
password = ""
}
hibernate {
cache.use_second_level_cache = true
cache.use_query_cache = false
cache.region.factory_class = 'net.sf.ehcache.hibernate.EhCacheRegionFactory' // Hibernate 3
// cache.region.factory_class = 'org.hibernate.cache.ehcache.EhCacheRegionFactory' // Hibernate 4
}
// environment specific settings
environments {
development {
dataSource {
dbCreate = "create-drop" // one of 'create', 'create-drop', 'update', 'validate', ''
url = "jdbc:h2:mem:devDb;MVCC=TRUE;LOCK_TIMEOUT=10000"
}
}
当使用控制台而不是 groovy shell 创建实体时,问题仍然存在。
我目前正在使用最新的 grails 版本,即 2.3.1
嵌入式 H2 数据库 vrsion = H2 1.3.173 (2013-07-28)