Grails开发中的数据处理、消息服务与邮件发送
1. 数据加载与事务处理
在数据加载方面,不同的配置会带来不同的行为。当进行特定配置时,书籍表(book table)会有一个外键指向作者表(author table),加载书籍实例可以通过一条查询完成,类似于 select * from book where author_id=? 。这种情况下,实例不是代理对象,所有数据都会被加载。这里存在一个权衡,即使用一条大查询加载 100% 的数据(非懒加载属性),与使用 N + 1 条查询按需加载数据。
如果使用更简单的 belongsTo 语法,会得到一个连接表和代理对象,就像关系不是双向的情况一样,示例代码如下:
class Book {
String title
static belongsTo = Author
}
事务性写后处理(Transactional write - behind)是另一个有助于减少访问数据库次数的特性。Hibernate 会尽可能长时间地对更新实例的 save() 调用和 delete() 调用进行排队,理想情况下,会在关闭会话前的 flush() 调用时执行这些操作。这意味着,如果在代码中有一个复杂的工作流,在不同地方多次检索和修改一个实例,通常最终在数据库中只会有一次更新。
可以通过以下两种方式显式地提前刷新会话:
- 访问当前会话并调用 flus
超级会员免费看
订阅专栏 解锁全文
61

被折叠的 条评论
为什么被折叠?



