网站推荐、资源下载等 | 个人网站

hibernate的多对多配置

Teacher.java

 1 package com.xiaostudy.domain;
 2 
 3 import java.util.HashSet;
 4 import java.util.Set;
 5 
 6 /**
 7  * Teacher
 8  * 
 9  * @author xiaostudy
10  *
11  */
12 public class Teacher {
13     // id
14     private Integer id;
15     // 普通属性
16     private String name;
17     // 另一个类的集合
18     private Set<Student> students = new HashSet<Student>();
19 
20     // 自动生成get、set方法
21     public Integer getId() {
22         return id;
23     }
24 
25     public void setId(Integer id) {
26         this.id = id;
27     }
28 
29     public String getName() {
30         return name;
31     }
32 
33     public void setName(String name) {
34         this.name = name;
35     }
36 
37     public Set<Student> getStudents() {
38         return students;
39     }
40 
41     public void setStudents(Set<Student> students) {
42         this.students = students;
43     }
44 
45 }

Student.java

 1 package com.xiaostudy.domain;
 2 
 3 import java.util.HashSet;
 4 import java.util.Set;
 5 
 6 /**
 7  * Student
 8  * 
 9  * @author xiaostudy
10  *
11  */
12 public class Student {
13     // id
14     private Integer id;
15     // 普通属性
16     private String name;
17     // 另一个类的集合
18     private Set<Teacher> teachers = new HashSet<Teacher>();
19 
20     // 自动生成get、set方法
21     public Integer getId() {
22         return id;
23     }
24 
25     public void setId(int id) {
26         this.id = id;
27     }
28 
29     public String getName() {
30         return name;
31     }
32 
33     public void setName(String name) {
34         this.name = name;
35     }
36 
37     public Set<Teacher> getTeachers() {
38         return teachers;
39     }
40 
41     public void setTeachers(Set<Teacher> teachers) {
42         this.teachers = teachers;
43     }
44 
45     public void setId(Integer id) {
46         this.id = id;
47     }
48 
49 }

Teacher.hbm.xml

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <!DOCTYPE hibernate-mapping PUBLIC 
 3     "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
 4     "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
 5 <!-- 导入包 -->
 6 <hibernate-mapping package="com.xiaostudy.domain">
 7     <!-- name为bean的类名,table为数据库的表名 -->
 8     <class name="Teacher" table="t_teacher">
 9         <!-- name为bean的id,column为数据库表的列名 -->
10         <id name="id" column="id">
11             <!-- 设置自动更新表,表没有的话创建一个,有的话,再判断结构是否为所需,如有没有想应得列,会自动添加列,多余的也不会删除 -->
12             <generator class="native"></generator>
13         </id>
14         <!-- name为普通属性,column为数据库表的列名,type为数据类型 -->
15         <property name="name" column="name" type="string"></property>
16         <!-- name为bean中另一个类的集合名称,table为多对多中间的表,cascade为级联设置自动更新表 -->
17         <set name="students" table="t_teacher_student" cascade="save-update">
18             <!-- 自身连接外面的外键 -->
19             <key column="tid"></key>
20             <!-- column为另一个连接的外键,class为另一个bean的类名 -->
21             <many-to-many column="sid" class="Student"></many-to-many>
22         </set>
23     </class>
24 </hibernate-mapping>

Student.hbm.xml

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <!DOCTYPE hibernate-mapping PUBLIC 
 3     "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
 4     "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
 5 <hibernate-mapping package="com.xiaostudy.domain">
 6     <class name="Student" table="t_student">
 7         <id name="id" column="id">
 8             <generator class="native"></generator>
 9         </id>
10         <property name="name" column="name" type="string"></property>
11         <set name="teachers" table="t_teacher_student">
12             <key column="sid"></key>
13             <many-to-many column="tid" class="Teacher"></many-to-many>
14         </set>
15     </class>
16 </hibernate-mapping>

hibernate.cfg.xml

 1 <?xml version="1.0" encoding="UTF-8" ?>
 2 <!DOCTYPE hibernate-configuration PUBLIC
 3     "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
 4     "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
 5 
 6 <hibernate-configuration>
 7     <session-factory>
 8         <!-- 注册驱动 -->
 9         <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
10         <!-- mysql的用户名 -->
11         <property name="connection.username">root</property>
12         <!-- mysql的用户密码 -->
13         <property name="connection.password">123456</property>
14         <!-- 连接mysql的某库 -->
15         <property name="connection.url">jdbc:mysql://localhost:3306/user</property>
16         <!-- 控制台输出sql -->
17         <property name="show_sql">true</property>
18         <!-- 格式化输出的sql -->
19         <property name="format_sql">true</property>
20         <!-- 自动提交事务 -->
21         <!-- <property name="connection.autocommit">true</property> -->
22         <!-- 创建sql表
23             update:如果没有表,则创建一个。如果有表,而且表结构一致,那么不改变表。如果表结构不一样,会添加sql表缺少的列,多余的也不会删除。
24             create:不管sql表有没有存在,都会重新创建表。
25             create-drop:在create的基础上,每次关闭虚拟机时都会把表删除了。
26             validate:效验sql表,如果一致,则没有反应,如果不一致了,会抛出异常。
27          -->
28         <property name="hbm2ddl.auto">update</property>
29         <!-- 将Session与线程绑定=> 只有配置了该配置,才能使用getCurrentSession -->
30         <property name="current_session_context_class">thread</property>
31         <!-- 数据库方言配置 -->
32         <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
33         <!-- 导入映射文件 -->
34         <mapping resource="com/xiaostudy/domain/Teacher.hbm.xml"/>
35         <mapping resource="com/xiaostudy/domain/Student.hbm.xml"/>
36     </session-factory>
37 </hibernate-configuration>

Test1.java

 1 package com.xiaostudy.test;
 2 
 3 import org.hibernate.classic.Session;
 4 
 5 import com.xiaostudy.domain.Student;
 6 import com.xiaostudy.domain.Teacher;
 7 import com.xiaostudy.util.HibernateUtils;
 8 
 9 /**
10  * 测试多对多
11  * 
12  * @author xiaostudy
13  *
14  */
15 public class Test1 {
16 
17     public static void main(String[] args) {
18         //根据hibernate工具类,获取一个全新的Session
19         Session session = HibernateUtils.openSession();
20         //开始事务
21         session.beginTransaction();
22         Teacher teacher1 = new Teacher();
23         Teacher teacher2 = new Teacher();
24         teacher1.setName("t1");
25         teacher2.setName("t2");
26 
27         Student student1 = new Student();
28         Student student2 = new Student();
29         student1.setName("s1");
30         student2.setName("s2");
31 
32         //维护关系
33         teacher1.getStudents().add(student1);
34         teacher1.getStudents().add(student2);
35         teacher2.getStudents().add(student1);
36         teacher2.getStudents().add(student2);
37 
38         //持久化数据
39         session.save(teacher1);
40         session.save(teacher2);
41 
42         //关闭事务并提交事务
43         session.getTransaction().commit();
44         //关闭资源
45         session.close();
46     }
47 
48 }

码云:https://gitee.com/xiaostudy2/hibernate_manyToMany_demo/attach_files


 

posted @ 2018-08-22 22:41  xiaostudy  阅读(1478)  评论(0编辑  收藏  举报
网站推荐
[理工最爱]小时百科 |  GitHub |  Gitee |  开源中国社区 |  牛客网 |  不学网论坛 |  r2coding |  冷熊简历 |  爱盘 |  零散坑 |  bootstrap中文网 |  vue.js官网教程 |  源码分享站 |  maven仓库 |  楼教主网站 |  廖雪峰网站 |  w3cschool |  在线API |  代码在线运行 |  [不学网]代码在线运行 |  JS在线运行 |  PHP中文网 |  深度开源eclipse插件 |  文字在线加密解密 |  菜鸟教程 |  慕课网 |  千图网 |  手册网 |  素材兔 |  盘多多 |  悦书PDF |  sumatra PDF |  calibre PDF |  Snipaste截图 |  shareX截图 |  vlc-media-player播放器 |  MCMusic player |  IDM下载器 |  格式工厂 |  插件网 |  谷歌浏览器插件 |  Crx搜搜 |  懒人在线计算器 |  leetcode算法题库 |  layer官网 |  layui官网 |  formSelects官网 |  Fly社区 |  程序员客栈 |  融云 |  华为云 |  阿里云 |  ztree官网API |  teamviewer官网 |  sonarlint官网 |  editormd |  pcmark10官网 |  crx4chrome官网 |  apipost官网 |  花生壳官网 |  serv-u官网 |  杀毒eset官网 |  分流抢票bypass官网 |  懒猴子CG代码生成器官网 |  IT猿网 |  natapp[内网穿透] |  ngrok[内网穿透] |  深蓝穿透[内网穿透] |  WakeMeOnLan[查看ip] |  iis7 |  [漏洞扫描]Dependency_Check官网 |  [图标UI]fontawesome官网 |  idea插件官网 |  路过图床官网 |  sha256在线解密 |  在线正则表达式测试 |  在线文件扫毒 |  KuangStudy | 
资源下载
电脑相关: Windows原装下载msdn我告诉你 |  U盘制作微PE工具官网下载 |  Linux_CentOS官网下载 |  Linux_Ubuntu官网下载 |  Linux_OpenSUSE官网下载 |  IE浏览器官网下载 |  firefox浏览器官网下载 |  百分浏览器官网下载 |  谷歌google浏览器历史版本下载 |  深度deepin系统官网下载 |  中兴新支点操作系统官网下载 |  文件对比工具Beyond Compare官网下载 |  开机启动程序startup-delayer官网下载 |  openoffice官网下载 |  utorrent官网下载 |  qbittorrent官网下载 |  cpu-z官网下载 |  蜘蛛校色仪displaycal官网下载 |  单文件制作greenone下载 |  win清理工具Advanced SystemCare官网下载 |  解压bandizip官网下载 |  内存检测工具memtest官网下载 |  磁盘坏道检测与修复DiskGenius官网下载 |  磁盘占用可视化SpaceSniffer官网下载 |  [磁盘可视化]WizTree官网下载 |  win快速定位文件Everything官网下载 |  文件定位listary官网下载 |  动图gifcam官网下载 |  7-Zip官网下载 |  磁盘分区工具diskgenius官网下载 |  CEB文件查看工具Apabi Reader官网下载 |  罗技鼠标options官网下载 |  [去除重复文件]doublekiller官网下载 | 
编程相关: ApacheServer官网下载 |  Apache官网下载 |  Git官网下载 |  Git高速下载 |  Jboss官网下载 |  Mysql官网下载 |  Mysql官网历史版本下载 |  NetBeans IDE官网下载 |  Spring官网下载 |  Nginx官网下载 |  Resin官网下载 |  Tomcat官网下载 |  jQuery历史版本下载 |  nosql官网下载 |  mongodb官网下载 |  mongodb_linux历史版本下载 |  mongodb客户端下载 |  VScode官网下载 |  cxf官网下载 |  maven官网下载 |  QT官网下载 |  SVN官网下载 |  SVN历史版本下载 |  nodeJS官网下载 |  oracle官网下载 |  jdk官网下载 |  STS官网下载 |  STS历史版本官网下载 |  vue官网下载 |  virtualbox官网下载 |  docker desktop官网下载 |  github desktop官网下载 |  EditPlus官网下载 |  zTree下载 |  layui官网下载 |  jqgrid官网下载 |  jqueryui官网下载 |  solr历史版本下载 |  solr分词器ik-analyzer-solr历史版本下载 |  zookeeper历史版本官网下载 |  nssm官网下载 |  elasticsearch官网下载 |  elasticsearch历史版本官网下载 |  redis官网下载 |  redis历史版本官网下载 |  redis的win版本下载 |  putty官网下载 |  查看svn密码TSvnPD官网下载 |  MongoDB连接工具Robo官网下载 |  dll查看exescope官网下载 |  dll2c官网下载 |  接口测试apipost官网下载 |  接口测试postman官网下载 |  原型设计工具AxureRP官网下载 |  canal官网下载 |  idea主题样式下载 |  vue的GitHub下载 |  finalShell官网下载 |  ETL工具kafka官网下载 |  cavaj[java反编译]官网下载 |  jd-gui[java反编译]官网下载 |  radmin[远程连接]官网下载 |  tcping[win ping端口]下载 |  jQueryUploadFile官网下载 |  RedisPlus下载 |  aiXcoder智能编程助手官网下载 |  [表单效验]validform官网下载 |  idea官网下载 |  RedisStudio下载 |  MD转word含公式pandoc官网下载 |  logviewer官网下载 |  Kafka官网下载 |  hbase高速下载 |  hadoop官网下载 |  hadooponwindows的GitHub下载 |  hive官网下载 |  soapui官网下载 |  flink官网下载 |  kafkatool官网下载 |  MinIO官网下载 |  MinIO中国镜像下载 | 
办公相关工具
免费在线拆分PDF【不超过30M】 |  免费在线PDF转Word【不超过10M】 |  在线文字识别转换【不超过1M】 |  PDF转换成Word【不超过50M】 |  在线OCR识别 |  Smallpdf |  文件转换器Convertio |  迅捷PDF转换器 |  字母大小写转换工具 |  档铺 |  快传airportal[可文字] |  快传-文叔叔 |  P2P-小鹿快传 |  [图床]ImgURL | 
网站入口
腾讯文档 |  有道云笔记网页版 |  为知笔记网页版 |  印象笔记网页版 |  蓝奏云 |  QQ邮箱 |  MindMaster在线思维导图 |  bilibili |  PDM文件在线打开 |  MPP文件在线打开 |  在线PS软件 |  在线WPS |  阿里云企业邮箱登陆入口 | 
其他
PDF转换 |  悦书PDF转换 |  手机号注册查询 |  Reg007 |  akmsg |  ip8_ip查询 |  ipip_ip查询 |  天体运行testtubegames |  测试帧率 |  在线网速测试 |