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加载的区别

Angular Lazy Loading

使用 hibernate.enable_lazy_load_no_trans 解决 Hibernate Lazy-Init 问题

前端优化 lazy-load(懒加载)

sh lazy-load.sh

html lazy_load.html