JPA 菜鸟教程 21 JPA2.0 @MapKeyColumn

原创 2017年01月05日 21:53:27

GitHub

@MapKeyColumn

用@JoinColumn注解和@MapKeyColumn处理一对多关系

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_employee_map` (
  `Employee_id` bigint(20) NOT NULL,
  `emp_value` varchar(255) DEFAULT NULL,
  `emp_key` varchar(255) NOT NULL,
  PRIMARY KEY (`Employee_id`,`emp_key`),
  CONSTRAINT `FK_k06nikcsc4pc9oasboix6uagw` FOREIGN KEY (`Employee_id`) REFERENCES `t_employee` (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

Employee

package com.jege.jpa;

import java.util.HashMap;
import java.util.Map;

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.MapKeyColumn;
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
  // 生成的表的主键Map.key+EmployeeMap_id
  @CollectionTable(name = "t_employee_map")
  @MapKeyColumn(name = "emp_key")
  @Column(name = "emp_value")
  private Map<String, String> others = new HashMap<String, 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 Map<String, String> getOthers() {
    return others;
  }

  public void setOthers(Map<String, String> others) {
    this.others = others;
  }



}

JPA2Test

package com.jege.jpa;

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

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();// Session
  }

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

    employee.getOthers().put("home", "beijing");
    employee.getOthers().put("work", "shanghai");
    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.getOthers());
  }

  @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

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

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

@MapKey与@MapKeyColumn二者区别

@MapKey与@MapKeyColumn二者区别

MyBatis使用@MapKey注解接收多个查询记录到Map中,以便方便地用get()方法获取字段的值

需求场景: 批量从数据库查出若干条数据,包括id和name两个字段。希望可以把结果直接用Map接收,然后通过map.get(id)方便地获取name的值。 问题: 如果使用下面的代码,则...

Mybatis select返回值为map时,选取表字段的两列作为key,value

最近需要用到Mybatis中查询结果集为Map的功能,查了好多资料,最终搞定。其实只需要重写ResultHandler接口,,然后用SqlSession 的select方法,将xml里面的映射文件的返...
  • sou_liu
  • sou_liu
  • 2015年08月18日 18:00
  • 34929

Java Map 按Key排序和按Value排序

Map排序的方式有很多种,这里记录下自己总结的两种比较常用的方式:按键排序(sort by key), 按值排序(sort by value)。 1、按键排序 jdk内置的java.u...
  • FX_SKY
  • FX_SKY
  • 2013年01月22日 11:01
  • 11723

Map之一个Key存多个Value的MultiValueMap(一个键多个值)

在日常的开发中经常用到键值对,也就是`Map`啦,我们知道Map是一个接口,它的特点是一个Key对应一个Value,也就是一个键对应一个值,但是往往我们需要一个Key对应多个Value,这种时候系统的...

jpa 注解 Map

@ElementCollection @MapKeyColumn(name="name") @Column(name="value") @CollectionTable(nam...

让JPA的Query回到Map对象

在JPA 2.0 中我们可以使用entityManager.createNativeQuery()来执行原生的SQL语句。 但当我们查询结果没有对应实体类时,query.getResultList()...
  • a9529lty
  • a9529lty
  • 2014年03月20日 10:10
  • 27698

Json串与实体的相互转换 (不依赖于jar包 只需Eclipse环境即可)

Json串与实体的相互转换 (不依赖于jar包 只需Eclipse环境即可) 最近学习了javaWeb开发,用的是ssh框架里面自己整合了hibernate 和Struts2 和spring框架,其...

软件重构的简单认识

1.定义          在软件工程学中重构(Refactoring)就是在不改变软件现有功能的基础上,通过调整程序代码改善软件的质量、性能,使其程序的设计模式和架构更趋合理,提高软件的扩展性...
  • dxswzj
  • dxswzj
  • 2013年05月13日 15:40
  • 1722

JPA 菜鸟教程 1 环境搭建

JPA JPA全称Java Persistence API. JPA通过JDK 5.0注解或XML描述对象-关系表的映射关系,并将运行期的实体对象持久化到数据库中。 Hibernate3.2+、T...
  • JE_GE
  • JE_GE
  • 2016年12月07日 22:41
  • 585
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:JPA 菜鸟教程 21 JPA2.0 @MapKeyColumn
举报原因:
原因补充:

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