Hibernate中的多表查询及抓取策略

发布时间 - 2026-01-10 23:09:32    点击率:

1.Hibernate中的多表查询

 1.1SQL中的多表查询

【交叉连接】

select * from A,B;

【内连接】

显示内连接:inner join(inner 可以省略)

Select * from A inner join B on 条件;

隐式内连接:

Select * from A,B where 条件;

【外连接】

左外连接:left outer join

Select * from A left outer join B on 条件;

右外连接:right outer join

Select * from A right outer join B on 条件;

1.2Hibernate中的多表连接查询

【交叉连接】

交叉连接

【内连接】

显示内连接 from Customer c inner join c.linkmans

隐式内连接

迫切内连接from Customer c inner join fetch c.linkmans

【外连接】

左外连接

右外连接

迫切左外连接

2.Hibernate中的抓取策略

2.1 延迟加载lazy

lazy延迟加载: 查询的时候不发送sql语句,在使用对象的时候才发送sql语句查询

延迟加载氛围类级别的延迟加载和关联级别的延迟加载

2.1.1类级别的延迟加载

使用延迟加载的方法查询某个类的时候是否采用的延迟称为是类级别的延迟。默认值是true。

Customer customer = session.load(Customer.class,1l);// 默认就会采用延迟加载,这种称为是类级别的延迟。 

类级别延迟加载失效:

* final修饰这个类,不能产生代理类,延迟加载就会失效。

* 在<class>上配置lazy=”false”

2.1.2关联级别的延迟加载

查询到某个对象以后,获得其关联的对象。查询其关联对象的时候是否采用的延迟。称为是关联级别的延迟。

Customer c = session.get(Customer.class,1l);
c.getLinkMans(); // 查询关联对象的时候,是否采用延迟加载。

关联级别的延迟往往会与抓取策略一起使用,优化程序。(关联级别的延迟在<set>或者是<many-to-one>标签上的延迟加载)

2.2抓取策略

抓取策略指的是查找到某个对象后,抓取其关联的对象的时候采用的策略。抓取策略就是在关联对象的配置上(<set>和<many-to-one>)配置fetch属性。

2.2.1 在set上配置的lazy和fetch

fetch:抓取策略,控制SQL语句的发送的格式。

    * select    :默认值。发送一条select语句查询关联对象。

    * join  :发送一条迫切左外连接查询关联对象。

    * subselect :发送一条子查询查询关联对象。

lazy:延迟加载,控制SQL语句的发送的时候。

    * true  :默认值。采用延迟加载。

    * false :不采用延迟加载。

    * extra :及其懒惰。

2.2.2 在many-to-one上配置的lazy和fetch

fetch:抓取策略,控制SQL语句的发送的格式。

    * select    :默认值.发送一条select语句查询关联对象。

    * join  :发送一条迫切左外连接查询关联对象。

lazy:延迟加载,控制SQL的发送的时机。

    * proxy :默认值。是否采用延迟,需要由另一方类上的延迟加载来决定。

    * false :不采用延迟加载。

    * no-proxy:

2.2.3 批量抓取

  批量抓取:查询了多个客户的时候,查询多个客户下的所有联系人。

  在Customer.hbm.xml中<set>上配置batch-size=”n”

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!


# hibernate多表查询  # hibernate抓取策略  # 浅谈hibernate中多表映射关系配置  # hibernate多表操作实例代码  # 加载  # 默认值  # 就会  # 多个  # 隐式  # 或者是  # 指的是  # 往往会  # 取其  # 就是在  # outer  # left  # Select  # SQL  # linkmans  # Customer  # fetch  # style  # color  # Hibernate 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何用狗爹虚拟主机快速搭建网站?  Python自动化办公教程_ExcelWordPDF批量处理案例  如何撰写建站申请书?关键要点有哪些?  Laravel如何实现API版本控制_Laravel版本化API设计方案  学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?  如何在腾讯云服务器上快速搭建个人网站?  Android自定义控件实现温度旋转按钮效果  Laravel的Blade指令怎么自定义_创建你自己的Laravel Blade Directives  如何在阿里云高效完成企业建站全流程?  潮流网站制作头像软件下载,适合母子的网名有哪些?  Laravel如何处理JSON字段_Eloquent原生JSON字段类型操作教程  ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】  如何在阿里云通过域名搭建网站?  LinuxCD持续部署教程_自动发布与回滚机制  laravel怎么配置Redis作为缓存驱动_laravel Redis缓存配置教程  Android中AutoCompleteTextView自动提示  Laravel怎么实现一对多关联查询_Laravel Eloquent模型关系定义与预加载【实战】  Laravel安装步骤详细教程_Laravel环境搭建指南  ,交易猫的商品怎么发布到网站上去?  怎样使用JSON进行数据交换_它有什么限制  独立制作一个网站多少钱,建立网站需要花多少钱?  Android okhttputils现在进度显示实例代码  网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?  音乐网站服务器如何优化API响应速度?  JavaScript中如何操作剪贴板_ClipboardAPI怎么用  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?  ,怎么在广州志愿者网站注册?  黑客入侵网站服务器的常见手法有哪些?  使用PHP下载CSS文件中的所有图片【几行代码即可实现】  如何基于PHP生成高效IDC网络公司建站源码?  Laravel如何获取当前用户信息_Laravel Auth门面获取用户ID  智能起名网站制作软件有哪些,制作logo的软件?  中山网站推广排名,中山信息港登录入口?  php读取心率传感器数据怎么弄_php获取max30100的心率值【指南】  中山网站制作网页,中山新生登记系统登记流程?  如何在 Go 中优雅地映射具有动态字段的 JSON 对象到结构体  EditPlus中的正则表达式 实战(2)  如何快速选择适合个人网站的云服务器配置?  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  Win11关机界面怎么改_Win11自定义关机画面设置【工具】  如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?  如何快速生成ASP一键建站模板并优化安全性?  JavaScript常见的五种数组去重的方式  利用JavaScript实现拖拽改变元素大小  Laravel的契約(Contracts)是什么_深入理解Laravel Contracts与依赖倒置  JavaScript实现Fly Bird小游戏  大型企业网站制作流程,做网站需要注册公司吗?  网页制作模板网站推荐,网页设计海报之类的素材哪里好?  Laravel策略(Policy)如何控制权限_Laravel Gates与Policies实现用户授权  Thinkphp 中 distinct 的用法解析