标签:big util 配置 coding 联系人 -- 分页 语言 中间
目录
? 一对多
? 多对多
? 一对一
? 一对多
? 在多的一方创建一个外键,指向一的一方的主键
? 多对多
? 创建一个中间表,中间表至少有两个字段,分别作为外键指向多对多双方的主键
? 一对一
? 唯一外键对应
? 主键对应
创建表的 hbm.xml文件时,有外键可不创建列的映射
主表为客户(Customer),从表为联系人(Linkman)
销售联系人(linkman),一个联系人只能属于某一个客户
?
CREATE TABLE `linkman` (
`link_id` bigint(32) NOT NULL AUTO_INCREMENT COMMENT '联系人编号(主键)',
`link_name` varchar(16) DEFAULT NULL COMMENT '联系人姓名',
`link_cust_id` bigint(32) NOT NULL COMMENT '客户id',
`link_gender` char(1) DEFAULT NULL COMMENT '联系人性别',
`link_phone` varchar(16) DEFAULT NULL COMMENT '联系人办公电话',
`link_mobile` varchar(16) DEFAULT NULL COMMENT '联系人手机',
`link_email` varchar(64) DEFAULT NULL COMMENT '联系人邮箱',
`link_qq` varchar(16) DEFAULT NULL COMMENT '联系人qq',
`link_position` varchar(16) DEFAULT NULL COMMENT '联系人职位',
`link_memo` varchar(512) DEFAULT NULL COMMENT '联系人备注',
PRIMARY KEY (`link_id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;
客户(customer),一个客户可以有多个联系人
?
CREATE TABLE `customer` (
`cust_id` bigint(32) NOT NULL AUTO_INCREMENT COMMENT '客户编号(主键)',
`cust_name` varchar(32) NOT NULL COMMENT '客户名称(公司名称)',
`cust_source` varchar(32) DEFAULT NULL COMMENT '客户信息来源',
`cust_industry` varchar(32) DEFAULT NULL COMMENT '客户所属行业',
`cust_level` varchar(32) DEFAULT NULL COMMENT '客户级别',
`cust_phone` varchar(64) DEFAULT NULL COMMENT '固定电话',
`cust_mobile` varchar(16) DEFAULT NULL COMMENT '移动电话',
PRIMARY KEY (`cust_id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
客户实体类
private Long cust_id;
private String cust_name;
private String cust_source;
private String cust_industry;
private String cust_level;
private String cust_phone;
private String cust_mobile;
销售实体类
?
private Long link_id;
private String link_name;
private String link_gender;
private String link_phone;
private String link_mobile;
private String link_email;
private String link_qq;
private String link_position;
private String link_memo;
private String link_cust_id;
一个客户可以有多个联系人
package com.myxq.domain;
import lombok.Getter;
import lombok.Setter;
import java.util.HashSet;
import java.util.Set;
@Getter@Setter
public class Customer {
private Long cust_id;
private String cust_name;
private String cust_source;
private String cust_industry;
private String cust_level;
private String cust_phone;
private String cust_mobile;
//一个客户可以有多个联系人
private Set<Linkman> linkmens = new HashSet<>();
@Override
public String toString() {
return "Customer{" +
"cust_id=" + cust_id +
", cust_name='" + cust_name + '\'' +
", cust_source='" + cust_source + '\'' +
", cust_industry='" + cust_industry + '\'' +
", cust_level='" + cust_level + '\'' +
", cust_phone='" + cust_phone + '\'' +
", cust_mobile='" + cust_mobile + '\'' +
'}';
}
}
一个联系人只能属于某一个客户
package com.myxq.domain;
import lombok.Getter;
import lombok.Setter;
@Getter@Setter
public class Linkman {
private Long link_id;
private String link_name;
private String link_gender;
private String link_phone;
private String link_mobile;
private String link_email;
private String link_qq;
private String link_position;
private String link_memo;
private String link_cust_id;
//一个联系人只对应一个客户
private Customer customer;
@Override
public String toString() {
return "Linkman{" +
"link_id=" + link_id +
", link_name='" + link_name + '\'' +
", link_gender='" + link_gender + '\'' +
", link_phone='" + link_phone + '\'' +
", link_mobile='" + link_mobile + '\'' +
", link_email='" + link_email + '\'' +
", link_qq='" + link_qq + '\'' +
", link_position='" + link_position + '\'' +
", link_memo='" + link_memo + '\'' +
", link_cust_id='" + link_cust_id + '\'' +
", customer=" + customer +
'}';
}
}
?
1.客户(Customer)实体类的配置文件
customer.hbm.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="com.myxq.domain.Customer" table="customer" >
<!--建立类属性哪一个是主键 还要跟数据库当中主键进行对象-->
<id name="cust_id" column="cust_id" >
<generator class="native"/>
</id>
<!--建立类中的普通属性与数据库当中字段进行关联-->
<property name="cust_name" column="cust_name" />
<property name="cust_source" column="cust_source"/>
<property name="cust_industry" column="cust_industry"/>
<property name="cust_level" column="cust_level"/>
<property name="cust_phone" column="cust_phone"/>
<property name="cust_mobile" column="cust_mobile"/>
<!--一对多-->
<set name="linkmens" cascade="save-update,delete" inverse="true"><!--set属性名称-->
<key column="link_cust_id"></key><!--外键-->
<one-to-many class="com.myxq.domain.Linkman"></one-to-many>
</set>
</class>
</hibernate-mapping>
2.联系人(LinkMan)实体类配置文件
linkman.hbm.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="com.myxq.domain.Linkman" table="linkman" >
<!--建立类属性哪一个是主键 还要跟数据库当中主键进行对象-->
<id name="link_id" column="link_id" >
<generator class="native"/>
</id>
<!--建立类中的普通属性与数据库当中字段进行关联-->
<property name="link_name" column="link_name" />
<property name="link_gender" column="link_gender"/>
<property name="link_phone" column="link_phone"/>
<property name="link_mobile" column="link_mobile"/>
<property name="link_email" column="link_email"/>
<property name="link_qq" column=" link_qq"/>
<property name="link_position" column=" link_position"/>
<property name="link_memo" column=" link_memo"/>
<many-to-one name="customer" cascade="save-update" class="com.myxq.domain.Customer"
column="link_cust_id"/>
</class>
</hibernate-mapping>
问题
? 在两张表建立一对多关系时,如果只保存一边的对象,就会发异常
示例
? 在操作一个对象的时候,是否会操作其关联的对象。
? 级联保存或更新
? 级联删除
? 在操作一的一方,是否会操作多的一方
? 操作多的一方时, 是否会操作一的一方
? 操作的主体是谁,就要在谁的映射配置文件当中进行配置
? 在开始配置的set当中添加一个新的属性cascade="save-update"
? 在多的一方添加级联
? 再去运行,就不会报异常,两条记录都会被添加
? 在一的一方添加级联
?
? 两方如果都加了级联,这种我们也称为双向导航
? 设置双向导航时,当对象存在关系时, 就会做出对应的操作
?
删除一边数据时,同时将另一边的数据一并删除
? 默认:先把外键改为空,然后再删除
? 发送的SQL语句
示例代码
配置文件
原因
? 当双向维护时,两都都维护了外键,当做更新操作时, 两边的外键都要去修改
1.使用单向维护
? 有些地方还是会有问题
2.一方放弃维护权
? 在一的一方放弃外键维护权
? 在配置文件当中添加一个inverse="false/true"
? true为放弃外键维护权,false为不放弃外键维护权
? cascade控制有没有关联对象
? inverse控制有没有外键
? 示例
改成false,获取外键对象
在linkman.hbm.xml
<many-to-one name="customer" class="com.myxq.domain.Customer" column="link_cust_id"
lazy="false"/>
在customer.hbm.xml
<set name="linkmens" cascade="save-update,delete" inverse="true">
<!--set属性名称-->
<key column="link_cust_id"></key><!--外键-->
<one-to-many class="com.myxq.domain.Linkman">
</one-to-many>
</set>
用户表,一个用户可以有多个角色
?
CREATE TABLE `user` (
`user_id` bigint(32) NOT NULL AUTO_INCREMENT COMMENT '用户id',
`user_code` varchar(32) NOT NULL COMMENT '用户账号',
`user_name` varchar(64) NOT NULL COMMENT '用户名称',
`user_password` varchar(32) NOT NULL COMMENT '用户密码',
`user_state` char(1) NOT NULL COMMENT '1:正常,0:暂停',
PRIMARY KEY (`user_id`)
) ENGINE=InnoDB AUTO_INCREMENT=9 DEFAULT CHARSET=utf8;
角色表,一个角色可以被多个用户选择
CREATE TABLE `role` (
`role_id` bigint(32) NOT NULL AUTO_INCREMENT,
`role_name` varchar(32) NOT NULL COMMENT '角色名称',
`role_memo` varchar(128) DEFAULT NULL COMMENT '备注',
PRIMARY KEY (`role_id`)
) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8;
关系图
?
import lombok.Getter;
import lombok.Setter;
import java.util.HashSet;
import java.util.Set;
@Setter@Getter
public class Role {
private Long role_id;
private String role_name;
private String role_memo;
//角色下面的所有用户
private Set<User> users = new HashSet<>();
}
用户
角色
双向维护时,必须要有一方放弃外键维护
如果两边都有维护的话, 就会有重复的的记录,由于关系表是两个字段作为共同主键,不能有相同的记录
解决办法
? 通常都是让被动方放弃,用户选角色,角色为被动方
关系的操作,只需要操作集合,就可以操作它们之间的关系
给用户添加一个新的角色
修改一个用户的角色
删除角色
什么是OID查询
OID查询方式
什么是对象导航检索
有点像级联查询
? 位置绑定:根据参数的位置进行绑定条件
? 名称绑定:把参数对应的值起一个名称 再去设置名称
? 查询对象的某个或某些属性
? 单个属性
? 多个属性
? 查询多个属性,封装到对象当中
? 要在类中,提供构造方法
统#### 计查询
? 查询的结构只有一个
? 普通内连接
? 迫切内连接
?
? 通过hibernate将另一个对象的数据,封装该对象中
? 在普通内连接inner join 后添加一个关键字fetch
三大框架 之 Hibernate查询(一对多、多对多、查询关系)
标签:big util 配置 coding 联系人 -- 分页 语言 中间
原文地址:https://www.cnblogs.com/mumuyinxin/p/10708180.html