只记录双向的情况(双向是单向的一种)

 @OneToMany 和 @ManyToOne :一个Group 包含多个 User;

Group.class

package com.XX.model;

import java.util.HashSet;
import java.util.Set; import javax.persistence.CascadeType;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.OneToMany;
import javax.persistence.Table; import org.hibernate.annotations.GenericGenerator; @Entity
@Table(name = "t_group")
public class Group { private String id;
private String name;
private String title;
private Set<User> users;    //说明代码一
@Id
@GeneratedValue(generator = "sys-uuid")
@GenericGenerator(name = "sys-uuid", strategy = "uuid2")
public String getId() {
return id;
} public String getName() {
return name;
} public String getTitle() {
return title;
}   //说明代码二
@OneToMany(cascade = {CascadeType.ALL}, fetch=FetchType.EAGER, mappedBy = "group")
public Set<User> getUsers() {
return (users==null)? new HashSet<User>():users;
} public void setId(String id) {
this.id = id;
} public void setName(String name) {
this.name = name;
} public void setTitle(String title) {
this.title = title;
} public void setUsers(Set<User> users) {
this.users = users;
}   //说明代码三
/* public void addUser(User user) {
if(this.users == null){
this.users = new HashSet<User>();
}
users.add(user);
}*/
}

User.class

package com.XX.model;

import javax.persistence.CascadeType;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.ManyToOne;
import javax.persistence.Table; import org.hibernate.annotations.GenericGenerator; @Entity
@Table(name = "t_user")
public class User { private String id;
private String name;
private int age;
private Group group; @Id
@GeneratedValue(generator = "sys-uuid")
@GenericGenerator(name = "sys-uuid", strategy = "uuid2")
public String getId() {
return id;
} public String getName() {
return name;
} public int getAge() {
return age;
}
  
  //说明代码二
@ManyToOne(cascade = {CascadeType.ALL})
public Group getGroup() {
return group;
} public void setId(String id) {
this.id = id;
} public void setName(String name) {
this.name = name;
} public void setAge(int age) {
this.age = age;
} public void setGroup(Group group) {
this.group = group;
} }

测试代码: 

package com.XX.model;

import java.util.Set;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.boot.Metadata;
import org.hibernate.boot.MetadataSources;
import org.hibernate.boot.registry.StandardServiceRegistry;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
import org.junit.AfterClass;
import org.junit.BeforeClass;
import org.junit.Test; public class GroupTest { private static SessionFactory sessionFactory; @BeforeClass
public static void beforeClass(){
     //hibernate 5.0.0.Final及之后的写法
StandardServiceRegistry registry = new StandardServiceRegistryBuilder().configure().build(); Metadata metadata = new MetadataSources(registry).getMetadataBuilder().build();
sessionFactory = metadata.getSessionFactoryBuilder().build();
} @Test
public void test() {
Group group = new Group();
group.setName("group1");
group.setTitle("test"); User user = new User();
user.setName("yuc");
user.setAge(0); Set<User> users = group.getUsers();
users.add(user);
group.setUsers(users);
     //说明代码三
//group.addUser(user); Session session = sessionFactory.getCurrentSession();
session.beginTransaction();
session.save(group);
session.getTransaction().commit();      //说明代码四
session = sessionFactory.getCurrentSession();
session.beginTransaction();
session.get(Group.class, "1"); } @AfterClass
public static void afterClass(){
sessionFactory.close();
} }

  

说明代码一:

  ID用 String 存储,保存时自动生成,跨数据库(mysql、oracle均实用);

说明代码二:

  @manytoone & @onetomany 双向关联时,manytoone 一方用mappedBy 进行关联(否则数据库会出现两个关联关系,重复);  

代码说明三:

  在多的一方辅助增加一个子元素。不足:破坏bean 的完整性(一般bean层级只有元素和对应的get/set方法);

代码说明四:

  用于说明@manytoone 和 @onetomany 的默认加载方式:

  @manytoone 默认加载方式是FetchType.LAZY;

  @onetomany 默认加载方式是FetchType.EAGER;

运行代码如下:  

数据库结果如下:  

@manyToMany双向关联  :一个Teacher有多个Student,一个Student有多个Teacher;

Teacher.class

package com.ajs.model;

import java.util.Set;

import javax.persistence.CascadeType;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.ManyToMany;
import javax.persistence.Table; import org.hibernate.annotations.GenericGenerator; @Entity
@Table(name = "t_teacher")
public class Teacher { private String id;
private String name;
private String title;
private Set<Student> students; @Id
@GeneratedValue(generator = "sys-uuid")
@GenericGenerator(name = "sys-uuid", strategy = "uuid2")
public String getId() {
return id;
} //说明代码五
@ManyToMany(targetEntity=Student.class, fetch = FetchType.EAGER, cascade={CascadeType.ALL}, mappedBy = "teachers")
public Set<Student> getStudents() {
return students;
} public void setStudents(Set<Student> students) {
this.students = students;
} public void setId(String id) {
this.id = id;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public String getTitle() {
return title;
} public void setTitle(String title) {
this.title = title;
}
}

  

Student.class 

测试代码  

   @Test
public void test() {
Teacher teacher = new Teacher();
teacher.setName("tea1");
teacher.setTitle("test"); Student student = new Student();
student.setName("yuc");
student.setAge(20); Set<Student> students= new HashSet<Student>();
students.add(student);
teacher.setStudents(students);
Set<Teacher> teachers= new HashSet<Teacher>();
teachers.add(teacher);
student.setTeachers(teachers); Session session = sessionFactory.getCurrentSession();
session.beginTransaction();
session.save(teacher);
session.getTransaction().commit(); session = sessionFactory.getCurrentSession();
session.beginTransaction();
session.get(Student.class, "1");
}

  

说明代码五:

package com.ajs.model;

import java.util.Set;

import javax.persistence.CascadeType;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.JoinTable;
import javax.persistence.ManyToMany;
import javax.persistence.Table; import org.hibernate.annotations.GenericGenerator; @Entity
@Table(name = "t_student")
public class Student { private String id;
private String name;
private int age;
private Set<Teacher> teachers; @Id
@GeneratedValue(generator = "sys-uuid")
@GenericGenerator(name = "sys-uuid", strategy = "uuid2")
public String getId() {
return id;
} public String getName() {
return name;
} public int getAge() {
return age;
} //说明代码五
@ManyToMany(targetEntity=Teacher.class, fetch = FetchType.EAGER, cascade={CascadeType.ALL})
@JoinTable(name="t_teacher_student",
joinColumns=@JoinColumn(name="student_id"),
inverseJoinColumns=@JoinColumn(name="teacher_id"))
public Set<Teacher> getTeachers() {
return teachers;
} public void setId(String id) {
this.id = id;
} public void setName(String name) {
this.name = name;
} public void setAge(int age) {
this.age = age;
} public void setTeachers(Set<Teacher> teachers) {
this.teachers = teachers;
}
}

  

  双向一样用 mappedBy 对其中一方进行限制,fetch = FetchType.EAGER手动将加载方式改为急加载,需要用targetEntity指定对应的关联类是哪一个;

  @JoinTable(name="t_teacher_student", joinColumns=@JoinColumn(name="student_id"),inverseJoinColumns=@JoinColumn(name="teacher_id"))

  @JoinTable可以自定义对应的中间表名字,当前实体对象关联的中间表字段名称,已经中间表关联另一方的对应名称;

运行代码如下:

数据库结果如下:

one2many &&many2many的更多相关文章

  1. Mybatis对象关系映射 one2one,one2many,many2many

    MyBatis中的高级映射一般要借助select元素中的resultMap属性进行实现,通过此属性配置实现一对一,一对多等关系映射的实现 一对一映射:association 一对多映射:collect ...

  2. OpenERP 的XML-RPC的轻度体验+many2many,one2many,many2one创建方式

    来自:http://cn.openerp.cn/openerp_import_image_by_xmlrpc/ 每当夏秋之交,我们都有展会,展会完后,都有很多的新的潜在客户要添加,我们收了一大堆名片, ...

  3. laravel model relationship

    laravel支持多种模型之间的relation,对应着模型间的one2one, one2many,many2many,hasManyThrough,Polymorphic, many2many po ...

  4. 7、ORM

    CRUD(create.retrieve.update.delete) left join right join inner join one2one one2many many2many 1.For ...

  5. odoo domain详解

    参考的以下文档: luohuayong:Odoo domain写法及运用 baimo:odoo domain表达式 1.domain 表达式规则 最简单的格式:[('字段名','操作符',值)] 例: ...

  6. Odoo中的Widget

    转载请注明原文地址:https://www.cnblogs.com/ygj0930/p/10826144.html 一:Widget是什么 Odoo中定义了字段的显示形式,不同字段类型的字段都有其不同 ...

  7. openerp many2many

    many2many (0,0,{values}) 根据values里面的信息新建一个记录. (1,ID,{values})更新id=ID的记录(写入values里面的数据) (2,ID) 删除id=I ...

  8. Odoo Many2many 指定默认分组过滤

    在odoo里如果想单击某个菜单打开的页面是自带过滤的,可以在打开菜单的动作中添加默认过滤来实现,今天有同学在群里问,如何在Many2many的添加更多的弹出窗口中添加类似的过滤,其实是非常非常简单的, ...

  9. 在xml中对one2many 字段屏蔽 添加项目

    在xml中对one2many 字段(mrp_workorder_variation_line_ids) 设置 只有在草稿状态下才能编辑 <field name="mrp_workord ...

随机推荐

  1. LeetCode OJ:Burst Balloons(击破气球)

    Given n balloons, indexed from 0 to n-1. Each balloon is painted with a number on it represented by ...

  2. PentesterLab-From SQL Injection to Shell

    一.打开靶机ip出现如下界面: 随便点一下,点到test链接,访问了如下url:http://192.168.109.131/cat.php?id=1,这里出现了一个id,常规思路这个位置可能有sql ...

  3. Kotlin Reference (三) Coding Conventions

    most from reference 命名规则 1.使用驼峰式命名规则,尽量避免在命名中使用下划线 2.类型以大写字母开头 3.方法和属性以小写字母开头 4.使用4个空格缩进 5.public的方法 ...

  4. TF随笔-8

    #!/usr/bin/env python2 # -*- coding: utf-8 -*- """ Created on Mon Jul 10 09:35:04 201 ...

  5. EasyDarwin如何支持点播和RTMP/HLS直播?EasyDSS!

    2017年很长很长一段时间没有更新EasyDarwin开源项目了,虽然心里有很多EasyDarwin功能扩展的计划:比如同步录像.同步RTMP/HLS直播输出.拉模式转发优化.Onvif接入.GB28 ...

  6. keras 报错 ValueError: Tensor conversion requested dtype int32 for Tensor with dtype float32: 'Tensor("embedding_1/random_uniform:0", shape=(5001, 128), dtype=float32)'

    在服务器上训练并保存模型,复制到本地之后load_model()报错: ValueError: Tensor conversion requested dtype int32 for Tensor w ...

  7. JVM原理三-----GC模块,垃圾回收

    GC方法:在JVM启动时填入参数(比如:-XX:+UseConcMarkSweepGC ) 算法区分: 1.古老回收算法: Reference Counting  ,对象有一个引用,即增加一个计数,删 ...

  8. HDU1556 线扫

    昨天睡得太晚,今天又在看新算法,明天事情也多,烦,所以今天刷刷水题就过去了. 叫我用线段树,我反而搞不来 #include<cstdio> #include<cstdlib> ...

  9. Java并发--线程池的使用

    在前面的文章中,我们使用线程的时候就去创建一个线程,这样实现起来非常简便,但是就会有一个问题: 如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了,这样频繁创建线程就会大大降低系统 ...

  10. BZOJ4237 稻草人 【CDQ分治】

    Description JOI村有一片荒地,上面竖着N个稻草人,村民们每年多次在稻草人们的周围举行祭典. 有一次,JOI村的村长听到了稻草人们的启示,计划在荒地中开垦一片田地.和启示中的一样,田地需要 ...