JPA 菜鸟教程 20 JPA2.0 @CollectionTable

原创 2017年01月04日 20:58:46

GitHub

@CollectionTable

指定集合表的详细信息,如果是JPA1.0必须再写一个Pojo类

ddl语句

CREATE TABLE `t_employee` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;

CREATE TABLE `t_colors` (
  `employee_id` bigint(20) NOT NULL,
  `color` varchar(255) DEFAULT NULL,
  KEY `FK_105ywqy149ra7e238gil22nvr` (`employee_id`),
  CONSTRAINT `FK_105ywqy149ra7e238gil22nvr` FOREIGN KEY (`employee_id`) REFERENCES `t_employee` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

Employee

package com.jege.jpa;

import java.util.ArrayList;
import java.util.List;

import javax.persistence.CollectionTable;
import javax.persistence.Column;
import javax.persistence.ElementCollection;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.Table;

/**
 * @author JE哥
 * @email 1272434821@qq.com
 * @description:pojo模型
 */
@Entity
@Table(name = "t_employee")
public class Employee {
  @Id
  @GeneratedValue
  private Long id;
  private String name;
  @ElementCollection
  // 一对多集合,如果是JPA1.0必须再写一个Pojo类
  @CollectionTable(name = "t_colors", joinColumns = @JoinColumn(name = "employee_id"))
  @Column(name = "color")
  private List<String> colors = new ArrayList<String>();

  public Employee() {

  }

  public Employee(String name) {
    this.name = name;
  }

  public Long getId() {
    return id;
  }

  public void setId(Long id) {
    this.id = id;
  }

  public String getName() {
    return name;
  }

  public void setName(String name) {
    this.name = name;
  }

  public List<String> getColors() {
    return colors;
  }

  public void setColors(List<String> colors) {
    this.colors = colors;
  }

}

JPA2Test

package com.jege.jpa;

import java.util.List;

import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import javax.persistence.Query;

import org.junit.After;
import org.junit.AfterClass;
import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Test;

public class JPA2Test {

  private static EntityManagerFactory entityManagerFactory = null;
  private EntityManager entityManager = null;

  @BeforeClass
  public static void setUpBeforeClass() throws Exception {
    entityManagerFactory = Persistence.createEntityManagerFactory("com.jege.jpa");
  }

  @Before
  public void setUp() throws Exception {
    entityManager = entityManagerFactory.createEntityManager();
  }

  @Test
  public void persist() throws Exception {
    Employee employee = new Employee();
    employee.setName("je-ge");

    employee.getColors().add("red");
    employee.getColors().add("green");
    entityManager.getTransaction().begin();
    entityManager.persist(employee);
    entityManager.getTransaction().commit();
  }

  @Test
  public void find() throws Exception {
    persist();
    entityManager.clear();

    Employee employee = entityManager.find(Employee.class, 1L);
    System.out.println(employee.getName());
    System.out.println(employee.getColors());

  }

  @Test
  public void query() throws Exception {
    persist();
    Query query = entityManager.createQuery("select count(o) from Employee o");
    Long count = (Long) query.getSingleResult();
    System.out.println(count);
  }

  // public Employee(String name) {
  // this.name = name;
  // }
  @Test
  public void query1() throws Exception {
    persist();
    Query query = entityManager.createQuery("select new Employee(o.name) from Employee o");
    List<Employee> employees = query.getResultList();
    for (Employee employee : employees) {
      System.out.println(employee.getName());
    }
  }

  @Test
  public void query2() throws Exception {
    persist();
    Query query = entityManager.createQuery("select o from Employee o where o.name=?1").setParameter(1, "张三");
    List<Employee> employees = query.getResultList();
    for (Employee employee : employees) {
      System.out.println(employee.getName());
    }
  }

  @Test
  public void query3() throws Exception {
    persist();
    Query query = entityManager.createQuery("select o from Employee o where o.name=:name").setParameter("name", "张三");
    List<Employee> employees = query.getResultList();
    for (Employee employee : employees) {
      System.out.println(employee.getName());
    }
  }

  @Test
  public void query4() throws Exception {
    persist();
    Query query = entityManager.createNamedQuery("getAll");
    List<Employee> employees = query.getResultList();
    for (Employee employee : employees) {
      System.out.println(employee.getName());
    }
  }

  @Test
  public void query5() throws Exception {
    persist();
    Query query = entityManager.createNativeQuery("select * from emp", Employee.class);
    List<Employee> employees = query.getResultList();
    for (Employee employee : employees) {
      System.out.println(employee.getName());
    }
  }

  @After
  public void tearDown() throws Exception {
    if (entityManager != null && entityManager.isOpen())
      entityManager.close();
  }

  @AfterClass
  public static void tearDownAfterClass() throws Exception {
    if (entityManagerFactory != null && entityManagerFactory.isOpen())
      entityManagerFactory.close();
  }

}

源码地址

https://github.com/je-ge/jpa

如果觉得我的文章或者代码对您有帮助,可以请我喝杯咖啡。
您的支持将鼓励我继续创作!谢谢!
微信打赏
支付宝打赏

版权声明:本文为博主原创文章,未经博主允许不得转载。

Hibernate映射集合属性

集合属性大致有两种:一种是单纯的集合属性,例如List、Set或数组等集合属性;另一种是Map结构的集合属性,每个属性值都有对应的key映射。不管哪种类型的集合属性,都统一用@ElementColle...
  • owen_william
  • owen_william
  • 2016年03月06日 19:23
  • 1794

Hibernate4学习总结(4)--注解形式的集合映射,关联关系映射

本文将接着上文,讲解hibernate4的集合映射的注解和关联关系映射的注解。本文包括两个部分: 1.集合映射的注解。 2.关联关系映射的注解。 二、关联关系映射的注解...
  • qq_29829081
  • qq_29829081
  • 2016年04月04日 10:39
  • 4501

tableView与collectionView区别讲义

一句毫不夸张的话,同学们用tableView这个控件可能不亚于你使用label ,button这些控件,真的,用的太多了,那个项目中不是含有多个tableView啊?可是集合视图collectionV...
  • baidu_31683691
  • baidu_31683691
  • 2017年01月12日 16:19
  • 971

@ElementCollection 组件集合映射

问题描述: 一个人有家庭住址,也有单位地址;但是“地址”并不能失去人的存在而存在,所以是一个失去独立性的Pojo; 所以地址不能映射为一个实体,这时就需要映射为组件,及人的信息里边包含地址。是整体...
  • gudong2945
  • gudong2945
  • 2011年03月12日 23:00
  • 9256

JPA概要

JPA概要 摘要: JPA定义了Java ORM及实体操作API的标准。本文摘录了JPA的一些关键信息以备查阅。如果有hibernate的基础,通过本文也可以快速掌握JPA的基本概念及使用。 ...
  • holandstone
  • holandstone
  • 2014年04月14日 15:01
  • 4959

JPA 菜鸟教程 14 自定义类型-@Embedded+@Embeddable

自定义类型 在hibernate中实现自定义类型,需要去实现UserType接口即可或者以Component的形式提供。 JPA的@Embedded注解有点类似,通过此注解可以在Entity模型中...
  • JE_GE
  • JE_GE
  • 2016年12月20日 21:41
  • 1680

Table是怎样炼成的:Row、RowCollection

接下来的连续几篇,我们要演练作一个描述通用的二维表,并演示该二维表的继承通途。先定义数据行的状态 1    /**////  2    /// 数据行的状态 3    ///  4    publi...
  • shyleoking
  • shyleoking
  • 2007年02月13日 22:40
  • 775

关于collectionView和tableView的两种cell的出列方法的区别

相信好多人一定会对collectionView和tableView的两种cell出列方法有所疑问,下面以UICollection为例子进行举例说明 假设我们已经创建了一个collectionView,...
  • chelongfei
  • chelongfei
  • 2015年06月25日 11:53
  • 1741

Hibernate映射集合属性

集合属性大致有两种:一种是单纯的集合属性,例如List、Set或数组等集合属性;另一种是Map结构的集合属性,每个属性值都有对应的key映射。不管哪种类型的集合属性,都统一用@ElementColle...
  • owen_william
  • owen_william
  • 2016年03月06日 19:23
  • 1794

Hibernate4学习总结(4)--注解形式的集合映射,关联关系映射

本文将接着上文,讲解hibernate4的集合映射的注解和关联关系映射的注解。本文包括两个部分: 1.集合映射的注解。 2.关联关系映射的注解。 二、关联关系映射的注解...
  • qq_29829081
  • qq_29829081
  • 2016年04月04日 10:39
  • 4501
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:JPA 菜鸟教程 20 JPA2.0 @CollectionTable
举报原因:
原因补充:

(最多只允许输入30个字)