首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

初识Hibernate之关联映射(一)

本篇主要介绍的关联映射就是针对有着某种关联的多张表的各种操作,主要涉及内容如下: 组合主键的映射 组件的映射 单向多对一的映射 单向一对多的映射 双向一对多的映射 级联映射 一、组合主键的映射操作      ...而对于单向一对多的映射则是其的一个逆向的逻辑,相对而言比较难以理解。...也就是说,当Hibernate加载到这里的时候,两张表单独创建完成之后,我要回到这里来,这里有一个一对多的外键需要更新,该外键的表载体在Student中,外键的名称是grade_id,于是它就会去更新Student...五、双向一对多的映射      双向一对多或者双向多对一都是一个意思,这种形式的关联映射操作就是上述的两种映射的结合,在多的一段配置多对一映射,在一的一段配置一对多映射。...我们看看级联是怎么做的: ? 显然,在保存好grade之后,立马将自己set集合中的Student记录插入到Student表中,然后通过update语句更新他们的外键值。

1.3K80

springboot实战之ORM整合(JPA篇)

这是持久化操作中很重要的一个方面,通过面向对象而非面向数据库的查询语言查询数据,避免程序的SQL语句紧密耦合。 (3)ORM(object/relational metadata)元数据的映射。...@MappedSupperclass 用来申明一个超类,继承这个类的子类映射时要映射此类中的字段 @CreationTimestamp 数据库做插入时,自动填充时间 @UpdateTimestamp...数据库有更新时,自动更新时间 本例只用一个entity来演示,因此没有涉及到表与表的关联,常用表与表之间的关联注解如下 @JoinColumn 指定一个实体组织或实体的集合。...这是用在多对一和一对多关联。 @ManyToMany 定义了连接表之间的多对多一对多的关系。 @ManyToOne 定义了连接表之间的多对一的关系。...@OneToMany 定义了连接表之间存在一个一对多的关系。 @OneToOne 定义了连接表之间有一个一对一的关系。

6.1K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    SqlAlchemy 2.0 中文文档(十五)

    ,“widget”行将会插入,但不包括“favorite_entry_id”值,然后所有的“entry”行将被插入,引用父“widget”行,然后一个 UPDATE 语句将填充“widget”表的“favorite_entry_id...##可变主键/更新级联 当实体的主键更改时,引用主键的相关项也必须更新。...可变主键 / 更新级联 当实体的主键发生变化时,引用该主键的相关项也必须进行更新。...当特定的映射安排将导致两行彼此依赖时,请使用此标志,例如,一个表与一组子行之间存在一对多关系,并且还有一个列引用该列表中的单个子行(即两个表相互包含对方的外键)。...NULL 值 连接表继承的批量插入 使用 SQL 表达式的 ORM 批量插入 遗留会话批量插入方法 ORM“upsert”语句 按主键进行 ORM 批量更新 为具有多个参数集的

    26110

    菜鸟的mybatis实战教程

    sql (4)统计分组 四、分页查询 五、复杂查询 (1)一对多查询 (2)多对一查询 (3)多对多查询 (4)...上面的例子一对多查询说白了就是在User上增加了一个List用于存储一对多存放的用户发表的多篇文章,重点要做其实就是数据库表和该User类的映射,这是重中之重。...例如 关于标签,该标签主要用于“一对多”时的映射,例如List的映射,这里主要有property属性和ofType属性,property对应实体类的属性...查询结果 (3)多对多查询 多对多查询在mybatis里实现的方式跟一对多的方式差不多,只不过是要涉及到3张表的联合查询,同样要处理List,下面给出案例。...(1)批量查询用户 (2)批量删除用户 (3)批量插入用户 (4)批量更新用户 关于mybatis的批量更新个人觉得是比较让人恶心的,经过查询,发现目前主要有两种方式,一种是通过接收传进来的参数list

    1K20

    深入浅出MyBatis:「映射器」全了解

    另外,可以通过延迟加载、缓存提高数据查询的性能。 本篇就按照这个思路进行总结,首先列举下映射器的主要元素,每个元素提供的配置项和作用,然后重点介绍参数、结果映射、延迟加载、缓存、动态SQL等功能。...映射器的主要元素 映射器是由Java接口和XML文件(或注解)共同组成的,Java接口主要定义调用者接口,XML文件是配置映射器的核心文件,包括以下元素: select 查询语句,可以自定义参数,返回结果集...; insert 插入语句,返回一个整数,表示插入的条数; update 更新语句,返回一个整数,表示更新的条数; delete 删除语句,返回一个整数,表示删除的条数; sql 允许定义一部分SQL,...--配置映射规则--> 一对一--> 一对多--> 一对一和一对多,实际中,多对多关系的应用不多,因为比较复杂,会用一对多的关系把它分解为双向关系。

    95860

    Spring·JPA

    如果试图将空值(null)作为 first name 插入数据库表的话,就会触发数据库约束冲突,进而导致当前事务回滚。...JOINED:这种策略为每种类型创建一个单独的表。因此每个表只包含它所映射的实体的状态。加载实体时,JPA 需要从当前实体映射的所有表中加载相应的数据。...然后在 Person 实体中添加新字段引用 IdCard: @Entity @Table(name = "T_PERSON") public class Person { private IdCard...必须谨慎使用懒加载,因为在加载很多 person 数据时它会导致数以百计的额外的查询请求,而且要牢记需要单独加载每个 IDCard。...一对多(OneToMany) 以上例 Person 实体为例,每个 Person 都有一个或多个手机,现在新添加一个实体 Phone: @Entity @Table(name = "T_PHONE")

    3.4K30

    系统学习javaweb-10-Hibernate的配置与api操作

    关联映射、inverse控制反转、cascade级联操作、一对一、组件、继承 【package4】:com.csxiaoyao.session session缓存的使用 【package5...//(测试) 会自动加载映射文件:User.hbm.xml .buildSessionFactory(); 4 Hibernate中的映射 一对多、多对一映射(one2many) 多对多映射...(many2many) 一对一映射(one2one 多对一的特殊应用) 组件映射(component 多个bean合成一张表、基于主键/基于外键) 继承映射(extends 所有子类映射到一张表...、每个类映射一张表、每个子类映射一张表) 4.1 集合映射 (collection)用户与收货地址,一个用户对应多个地址 4.2 多对一与一对多映射 在一对多与多对一的关联关系中,保存数据最好的通过多的一方来维护关系...级联保存、更新、删除 4.3 多对多映射 维护关联关系 设置inverse属性,在多对多种维护关联关系的影响 1.

    94520

    MyBatis常见面试题总结

    (原创不易,你们对阿超的赞就是阿超持续更新的动力!)...缺点: SQL语句的编写工作量较大,尤其当字段多、关联表多时,对开发人员编写SQL语句的功底有一定要求。 SQL语句依赖于数据库,导致数据库移植性差,不能随意更换数据库。...向SQL语句传递参数麻烦,因为SQL语句的where条件不一定,可能多,也可能少,占位符需要和参数一一对应。 解决:Mybatis自动将java对象映射到sql语句。...order_no orderno ,order_price price form orders where order_id=#{id}; 第2种: 通过来映射字段名和实体类属性名的一一对应的关系...,如封装成一个类,要写包名加类名,基本数据类型则可以省略 一对1、一对多时,若有表的字段相同必须写别名,不然查询结果无法正常映射,出现某属性为空或者返回的结果与想象中的不同,而这往往是没有报错的。

    1.9K21

    Hibernate框架学习之注解配置关系映射

    单向的多对一的关联关系映射 单向的一对多的关联关系映射 单向的多对多的关联关系映射 双向的一对一关联关系映射 双向的一对多关联关系映射 双向的多对多关联关系映射 一、单向的一对一关联关系映射 首先,...不过这种由一的一端管理关联关系的情况有点反常规逻辑,因此不建议用一的一端管理整个关联关系。 四、单向的多对多的关联关系映射 对于单向的多对多关联关系,我们无法使用外键列进行管理。...当我们插入数据的时候,会首先分别插入两张表的记录,然后会根据userinfo表中的集合属性中的元素向连接表中进行插入。返回数据也是类似的。...而如果想要通过userinfo表查询到usercode表的引用相对容易些,因为userinfo表中有一个外键列可以使用。查两次表即可。...其实和我们介绍的单向多对一基本一样,只是此处的一的一端增加了一个一对多的映射,增加了对userinfo表的一个引用而已。

    2.3K90

    redis一级缓存和二级缓存_面试官让面试者先回去

    一级缓存中的key是由sql语句、条件、statement等信息组成一个唯一值。一级缓存中的value,就是查询出的结果对象。...答: Mybatis 仅支持 association 关联对象和 collection 关联集合对象的延迟加载,association指的就是一对一,collection 指的就是一对多查询。...,那么就会单独发送事先保存好的查询关联 B 对象的 sql,把 B 查询上来,然后调用 a.setB(b),于是 a 的对象 b 属性就有值了,接着完成 a.getB().getName()方法的调用。...10.当实体类中的属性名和表中的字段名不一样,如果将查询的结果封装到指定 pojo? 答: 1)通过在查询的 sql 语句中定义字段名的别名。...2)通过来映射字段名和实体类属性名的一一对应的关系。

    2.7K10

    Hibernate总结以及在面试中的一些问题.

    他很大程度的简化DAO层的编码工作 ③.hibernate 的性能非常好,因为它是个轻量级框架。映射的灵活性很出色。它支持各种关系数据库,从一对一到多对多的各种复杂关系。...1.使用双向一对多关联,不使用单向一对多 2.灵活使用单向一对多关联 3.不用一对一,用多对一取代 4.配置对象缓存,不使用集合缓存 5.一对多集合使用Bag,多对多集合使用Set 6....一对多: 该属性在多的一方。...在多对多关联关系中,关系的两端 inverse不能都设为false,即默认的情况是不对的,如果都设为false,在做插入操作时会导致在关系表中插入两次关系。...一对一: 其实是一对多的一个特例,inverse 的设置也是一样的,主要还是看关联关系的属性在哪一方,这一方的inverse=false。 多对一: 也就是一对多的反过来,没什么区别。

    1.6K120

    Mybatis中三种关联关系的实现

    嵌套查询相当于进行了两次查询,而连接查询将两张表连接然后再进行查询,这样只进行了一次查询 由于数据表要对实体类进行映射,所以每一种关联关系中都需要在java类中定义属性来进行关联,可以通过如图关联: ?...一对一查询 数据表实现:通过A表的主键引用B表的主键作为外键,就是说在A中主键和外键同一字段。 查询方式:嵌套查询,连接查询; 关系:丈夫和妻子(Husband Wife) 嵌套查询实现: ?...,传递给目标 select 语句作为参数; 一对多查询 数据表实现:使用一个外键进行关联,外键放在多方的表中; 关联属性:可以写在一方的实体类中也可以写在多方的实体类中; 写在一方中,使用list或别的集合进行关联...与一对一中类似,在resultMap的collection中声明中元素类型,然后插入参数,将查询结果进行映射; 自关联查询: 数据表:一张数据表中包含着所有的条目,条目之间为一对多的关系(一个栏目下面包含着多个栏目...复杂查询返回值是一个List: 由于一张表先和中间表连接,而中间表是多对多的关系;所以得到一个一对多的List形式查询结果; 类似这样一对多: ?

    2.4K20

    “设计应对变化”--实例讲解一个数据同步系统

    将同类型数据表映射成一个实体对象 1,复杂的同步需求 这里的数据表是关系数据库中的表,将数据表一对一的映射成实体对象是很成熟的技术了,例如大名鼎鼎的ORM持久化框架Hibernate,以及新近....数据同步程序发送端将使用SystemA.Model.dll,根据要同步的实体对象映射的数据表,到数据源查询数据,然后填充到实体类中; 数据同步程序接收端将使用SystemB.Model.dll,根据要同步的实体对象映射的数据表...,将实体类中的数据,插入或者更新到目标数据库中; 数据的查询和更新操作都由PDF.NET数据开发框架内置支持,不需要写一行SQL语句。...数据更新实体类必须继承一个数据更新接口: WcfMail.Interface.IDataSyncEntity namespace WFT_DataSyncModel  {   [Serializable...OK,所需的工作完成,我们只改了一下实体类的映射类型和编写了一个实体类查询文件,编译项目,重新发布,开始执行,剩下的只是每次修改一下配置文件的查询条件了,比如我现在正在使用的条件: where ID

    1K70

    SpringDataJPA笔记(1)-基础概念和注解

    继承。 entity class映射到一个或多个从表。从表根据主表的主键列(列名为referencedColumnName值的列),建立一个类型一样的主键列,列名由name属性定义。...,@ManyToOne,@OneToMany,@ManyToMany 一对一的关联,多对一的关联,一对多的关联,多对多的关联 @JoinTable JoinTable在many-to-many关系的所有者一边定义...是否允许插入 updatable: 是否允许更新 columnDefinition: 定义建表时创建此列的DDL secondaryTable: 从表名。...entity class的所有id field在id class都要定义,且类型一样。 @MapKey 在一对多,多对多关系中,我们可以用Map来保存集合对象。...默认用主键值做key,如果使用复合主键,则用id class的实例做key,如果指定了name属性,就用指定的field的值做key @OrderBy 在一对多,多对多关系中,有时我们希望从数据库加载出来的集合对象是按一定方式排序的

    4K20

    C# 数据操作系列 - 5. EF Core 入门

    Entity Framework 非Core版目前已经更新到了6代,这是一款经过检验的ORM框架。...EF可以在不使用任何配置的前提下,自动解析类与表之间的映射(具体的映射逻辑与我们手写的ORM工具类一致或相近)。 自动跟踪更改。...可以延迟加载需要的数据,外键引用属性、查询结果等 丰富的映射关系,支持一对一,一对多,多对多,甚至继承、单表多实例等 可以使用Linq 进行查询 非Core版的可以通过数据库表生成实体类,两种都可以通过实体类生成表...然后选择数据库: 这次与之前的选择不太一样,这次选择 SQLite这个数据库。这是一个超小型的数据库,可以不用安装任何附加软件,只要有一个文件,然后通过代码就可以访问了。...string Name { get; set; } public int ModelAId { get; set; } public ModelA modelA { get; set; } } 然后创建一个继承自

    2.6K10

    MyBatis(随笔2 : Sql映射文件 )

    Sql文件映射 这里只是笔记,属性详情,关键还是要多练 ——实例代码 MyBatisDemo MyBatis 真正的强大在于映射语句,专注于SQL,功能强大,SQL映射的配置却是相当简单 SQL映射文件的几个顶级元素...sql 可以重用的SQL块,也可以被其他语句引用 insert 映射插入语句 update 映射更新语句 delete 映射删除语句 select 映射查询语句 :--------: --------...不一致,MyBatis 文件映射不出来:而可以通过SQL 语句查询,列起别名形式进行, 改正: 但还是不好,而且 两表连接查询时候, Java一般会在实体类中存在另一个类型对象…这个怎么解决呢~ eg..., 而 collection 则表示 一对多; 即:查询人事部的所有员工; Java的部门类中就需要一个用户集合… 关于映射级别 可以在MyBatis-config.xml 中 < setting...: 直接表示返回结果类型,包括基本数据类型 和 复杂数据类型; resultMap: 则是对外部 resultMap 定义的引用,它的场景一般是 数据库字段与实体类属性名不一致使用; 或 两表连接

    13910

    高级框架-springDate-JPA 第二天【悟空教程】

    第3章 多表设计 3.1 表之间关系的划分 数据库中多表之间存在着三种关系,如图所示。 ? 从图可以看出,系统设计的三种实体关系分别为:多对多、一对多和一对一关系。...注意:一对多关系可以看为两种: 即一对多,多对一。所以说四种更精确。 明确: 我们今天只涉及实际开发中常用的关联关系,一对多和多对多。...第二步:在数据库中实现两张表的关系 第三步:在实体类中描述出两个实体的关系 第四步:配置出实体类和数据库表的关系映射(重点) 第4章 JPA 中的一对多 4.1 示例分析 我们采用的示例为客户和联系人...4.4.1 @OneToMany: 作用: 建立一对多的关系映射 属性: targetEntityClass:指定多的多方的类的字节码 mappedBy:指定从表实体类中引用主表对象的名称...targetEntity:配置目标的实体类。映射多对多的时候不用写。

    2.5K10
    领券