SQLAlchemy lazy load和eager load
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQLAlchemy lazy load和eager load相关的知识,希望对你有一定的参考价值。
参考技术A 我们先创建user和address两张表,并插入数据:对其进行默认的lazy load:
log显示它只运行了SQL:
直到访问user的addresses:
才查询其addresses:
将会执行:
在访问时就可以直接获得数据
需要注意的是以下这种多对一的情况:
对addresses实际上是没有filter的
这种情况需要使用Join + Eagerload的方法
在访问时就可以直接获得数据
同样需要注意的是多对一的情况:
Hibernate中load()和get()的区别,lazy加载和Eager加载的区别
Hibernate中load()和get()的区别:
get():是直接操作数据库,通过id获取数据封装对象,如果没有数据则返回null;
load():先在session缓存中查询,如果缓存中不存在,则延迟从数据库中查询,没发现符合条件的记录,则会抛出一个ObjectNotFoundException。在延迟查询中如果session关闭则会抛出no session异常
Hibernate中lazy加载和Eager加载的区别:
Eager加载:将当前表和关联的其它表一并查询出来,select的语句数目太多,需要频繁的访问数据库,会影响查询的性能。 【ManyToOne默认Eager加载】
lazy加载:只查询当前你操作的表,不会自动查询关联的其他表,在只操作一个表的前提下效率高【OneToMany默认lazy加载】
以上是关于SQLAlchemy lazy load和eager load的主要内容,如果未能解决你的问题,请参考以下文章
Hibernate中load()和get()的区别,lazy加载和Eager加载的区别
使用 hibernate.enable_lazy_load_no_trans 解决 Hibernate Lazy-Init 问题