Hibernate【映射】知识要点(一)

简介: Hibernate【映射】知识要点

前言

前面的我们使用的是一个表的操作,但我们实际的开发中不可能只使用一个表的…因此,本博文主要讲解关联映射

集合映射

需求分析:当用户购买商品,用户可能有多个地址。

数据库表

我们一般如下图一样设计数据库表,一般我们不会在User表设计多个列来保存地址的。因为每个用户的地址个数都不一的,会造成数据冗余

  • 创建两张数据表,一张保存着用户的信息,一张保存着地址的信息。地址表使用外键来引用用户表

微信图片_20220221143545.png这里写图片描述

实体

由于地址只是使用String类型来保存着,那么我们直接使用一个User对象就可以了

public class User {
    private String id;
    private String username;
    private String password;
    private Set<String> address;
    //各种setter和getter

映射文件

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<!--在domain包下-->
<hibernate-mapping package="zhongfucheng.domain">
    <class name="User" table="user">
        <!--主键映射-->
        <id name="id" column="id" >
            <generator class="native"/>
        </id>
        <!--普通字段映射-->
        <property name="username" column="username"></property>
        <property name="password" column="password"></property>
        <!--
             Set:
                name: 映射集合的名称
                table:集合的属性要映射到哪张表(address)
             key:
                column:指定要映射的表(address)中的外键列
                element:要映射的表的其他字段
                    类型一定要指定!
        -->
        <set name="address" table="address">
            <key column="user_id"></key>
            <element column="addr" type="string"></element>
        </set>
    </class>
</hibernate-mapping>


测试:


package zhongfucheng.domain;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.hibernate.classic.Session;
/**
 * Created by ozc on 2017/5/6.
 */
public class App {
    public static void main(String[] args) {
        //创建对象
        User user = new User();
        user.setUsername("123");
        user.setPassword("1234");
        user.getAddress().add("广州");
        //获取加载配置管理类
        Configuration configuration = new Configuration();
        //加载User的映射文件!
        configuration.configure().addClass(User.class);
        //创建Session工厂对象
        SessionFactory factory = configuration.buildSessionFactory();
        //得到Session对象
        Session session = factory.openSession();
        //使用Hibernate操作数据库,都要开启事务,得到事务对象
        Transaction transaction = session.getTransaction();
        //开启事务
        transaction.begin();
        session.save(user);
        //提交事务
        transaction.commit();
        //关闭Session
        session.close();
    }
}

微信图片_20220221143549.png这里写图片描述


List集合映射配置

既然我们现在已经会了如何配置Set集合了,List集合又怎么配置呢??

想一下,List集合和Set集合有什么区别…List集合是有序的,因此要多配置一个列来维护数据的有序性!

<list name="address" table="address">
            <key column="user_id"></key>
            <!--index是关键字,不能使用!!!!-->
            <list-index column="indexNum"></list-index>
            <element column="addr" type="string"></element>
        </list>

Map集合映射配置

Map集合和Collection集合的区别就是键值对模型,那么在配置的时候多一个key即可!

<map name="address" table="address">
            <key column="user_id"  ></key>
            <map-key type="string" column="short"></map-key>
            <element type="string" column="addr"></element>
        </map>

微信图片_20220221143551.png这里写图片描述

目录
相关文章
|
4月前
|
Java 数据库连接 mybatis
一文彻底搞懂Mybatis系列(十一)之MyBatis多对一映射查询
一文彻底搞懂Mybatis系列(十一)之MyBatis多对一映射查询
|
10月前
|
XML 存储 Java
Hibernate框架【三】——基本映射——一对一映射
Hibernate框架【三】——基本映射——一对一映射
47 0
|
12月前
|
SQL 存储 Java
MyBatis-21MyBatis高级结果映射【一对多映射(2种方式)】
MyBatis-21MyBatis高级结果映射【一对多映射(2种方式)】
77 0
|
Java 数据库连接 数据库
|
Java 数据库连接 数据库
十二、MyBatis实现一对多映射处理
准备 数据库表 员工表(t_employee)
87 0
十二、MyBatis实现一对多映射处理
|
存储 SQL Java
hibernate学习笔记之二(映射关系与懒加载)
hibernate学习笔记之二(映射关系与懒加载)
hibernate学习笔记之二(映射关系与懒加载)
|
SQL Java 数据库连接
Hibernate【映射】知识要点(二)
Hibernate【映射】知识要点
122 0
Hibernate【映射】知识要点(二)
|
SQL Java 数据库连接
Hibernate【映射】知识要点(三)
Hibernate【映射】知识要点
92 0
Hibernate【映射】知识要点(三)
|
Java 数据库连接 数据库
Hibernate【映射】知识要点(四)
Hibernate【映射】知识要点
105 0
Hibernate【映射】知识要点(四)
|
Java 数据库连接 数据库
Hibernate【映射】续篇(二)
Hibernate【映射】续篇
94 0
Hibernate【映射】续篇(二)