博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
jpa 去重_JPA 查询Distinct Join条件示例
阅读量:6279 次
发布时间:2019-06-22

本文共 9276 字,大约阅读时间需要 30 分钟。

JPA教程 - JPA查询Distinct Join条件示例

以下查询使用distinct关键字以获取连接条件的唯一值。List l = em.createQuery(

"SELECT DISTINCT e.department FROM Project p JOIN p.employees e WHERE p.name = "proj"")

.getResultList();

例子

以下代码来自Phone.java。package cn.w3cschool.common;

import javax.persistence.Entity;

import javax.persistence.Id;

import javax.persistence.ManyToOne;

@Entity

public class Phone {

@Id

private long id;

private String number;

private String type;

@ManyToOne

Professor employee;

public long getId() {

return id;

}

public void setId(long id) {

this.id = id;

}

public String getNumber() {

return number;

}

public void setNumber(String phoneNo) {

this.number = phoneNo;

}

public String getType() {

return type;

}

public void setType(String phoneType) {

this.type = phoneType;

}

public Professor getProfessor() {

return employee;

}

public void setProfessor(Professor employee) {

this.employee = employee;

}

public String toString() {

return "Phone id: " + getId() +

", no: " + getNumber() +

", type: " + getType();

}

}

下面的代码来自Department.java。package cn.w3cschool.common;

import java.util.HashSet;

import java.util.Set;

import javax.persistence.Entity;

import javax.persistence.Id;

import javax.persistence.OneToMany;

@Entity

public class Department {

@Id

private int id;

private String name;

@OneToMany(mappedBy="department")

private Set employees = new HashSet();

public int getId() {

return id;

}

public void setId(int deptNo) {

this.id = deptNo;

}

public String getName() {

return name;

}

public void setName(String deptName) {

this.name = deptName;

}

public Set getProfessors() {

return employees;

}

public String toString() {

return "Department no: " + getId() +

", name: " + getName();

}

}

以下代码来自Professor.java。package cn.w3cschool.common;

import java.util.ArrayList;

import java.util.Collection;

import java.util.Date;

import javax.persistence.Entity;

import javax.persistence.Id;

import javax.persistence.ManyToMany;

import javax.persistence.ManyToOne;

import javax.persistence.OneToMany;

import javax.persistence.OneToOne;

import javax.persistence.Temporal;

import javax.persistence.TemporalType;

@Entity

public class Professor {

@Id

private int id;

private String name;

private long salary;

@Temporal(TemporalType.DATE)

private Date startDate;

@OneToOne

private Address address;

@OneToMany(mappedBy="employee")

private Collection phones = new ArrayList();

@ManyToOne

private Department department;

@ManyToOne

private Professor manager;

@OneToMany(mappedBy="manager")

private Collection directs = new ArrayList();

@ManyToMany(mappedBy="employees")

private Collection projects = new ArrayList();

public int getId() {

return id;

}

public void setId(int empNo) {

this.id = empNo;

}

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

public long getSalary() {

return salary;

}

public void setSalary(long salary) {

this.salary = salary;

}

public Date getStartDate() {

return startDate;

}

public void setStartDate(Date startDate) {

this.startDate = startDate;

}

public Collection getPhones() {

return phones;

}

public void addPhone(Phone phone) {

if (!getPhones().contains(phone)) {

getPhones().add(phone);

if (phone.getProfessor() != null) {

phone.getProfessor().getPhones().remove(phone);

}

phone.setProfessor(this);

}

}

public Department getDepartment() {

return department;

}

public void setDepartment(Department department) {

if (this.department != null) {

this.department.getProfessors().remove(this);

}

this.department = department;

this.department.getProfessors().add(this);

}

public Collection getDirects() {

return directs;

}

public void addDirect(Professor employee) {

if (!getDirects().contains(employee)) {

getDirects().add(employee);

if (employee.getManager() != null) {

employee.getManager().getDirects().remove(employee);

}

employee.setManager(this);

}

}

public Professor getManager() {

return manager;

}

public void setManager(Professor manager) {

this.manager = manager;

}

public Collection getProjects() {

return projects;

}

public void addProject(Project project) {

if (!getProjects().contains(project)) {

getProjects().add(project);

}

if (!project.getProfessors().contains(this)) {

project.getProfessors().add(this);

}

}

public Address getAddress() {

return address;

}

public void setAddress(Address address) {

this.address = address;

}

public String toString() {

return "Professor " + getId() +

": name: " + getName() +

", salary: " + getSalary() +

", phones: " + getPhones() +

", managerNo: " + ((getManager() == null) ? null : getManager().getId()) +

", deptNo: " + ((getDepartment() == null) ? null : getDepartment().getId());

}

}

以下代码来自Address.java。package cn.w3cschool.common;

import javax.persistence.Entity;

import javax.persistence.Id;

@Entity

public class Address {

@Id

private int id;

private String street;

private String city;

private String state;

private String zip;

public int getId() {

return id;

}

public void setId(int id) {

this.id = id;

}

public String getStreet() {

return street;

}

public void setStreet(String address) {

this.street = address;

}

public String getCity() {

return city;

}

public void setCity(String city) {

this.city = city;

}

public String getState() {

return state;

}

public void setState(String state) {

this.state = state;

}

public String getZip() {

return zip;

}

public void setZip(String zip) {

this.zip = zip;

}

public String toString() {

return "Address id: " + getId() +

", street: " + getStreet() +

", city: " + getCity() +

", state: " + getState() +

", zip: " + getZip();

}

}

下面的代码来自PersonDaoImpl.java。package cn.w3cschool.common;

import java.util.List;

import javax.persistence.EntityManager;

import javax.persistence.PersistenceContext;

import org.springframework.transaction.annotation.Transactional;

@Transactional

public class PersonDaoImpl {

public void test() {

prepareData();

List l = em.createQuery(

"SELECT DISTINCT e.department FROM Project p JOIN p.employees e WHERE p.name = "proj"")

.getResultList();

for (Object p : l) {

printResult(p);

}

}

private void prepareData() {

Address address = new Address();

address.setState("BC");

Professor p = new Professor();

p.setId(0);

p.setName("TOM");

p.setSalary(1111L);

p.setAddress(address);

Department d = new Department();

d.setId(1);

d.setName("Design");

p.setDepartment(d);

d.getProfessors().add(p);

Phone phone = new Phone();

phone.setId(1);

phone.setNumber("111-111-1111");

phone.setProfessor(p);

em.persist(p);

em.persist(phone);

em.persist(address);

em.persist(d);

}

private static void printResult(Object result) {

if (result == null) {

System.out.print("NULL");

} else if (result instanceof Object[]) {

Object[] row = (Object[]) result;

System.out.print("[");

for (int i = 0; i < row.length; i++) {

printResult(row[i]);

}

System.out.print("]");

} else if (result instanceof Long || result instanceof Double

|| result instanceof String) {

System.out.print(result.getClass().getName() + ": " + result);

} else {

System.out.print(result);

}

System.out.println();

}

@PersistenceContext

private EntityManager em;

}

以下代码来自Project.java。package cn.w3cschool.common;

import java.util.ArrayList;

import java.util.Collection;

import javax.persistence.Entity;

import javax.persistence.Id;

import javax.persistence.Inheritance;

import javax.persistence.ManyToMany;

@Entity

@Inheritance

public class Project {

@Id

protected int id;

protected String name;

@ManyToMany

protected Collection employees = new ArrayList();

public int getId() {

return id;

}

public void setId(int projectNo) {

this.id = projectNo;

}

public String getName() {

return name;

}

public void setName(String projectName) {

this.name = projectName;

}

public Collection getProfessors() {

return employees;

}

public void addProfessor(Professor employee) {

if (!getProfessors().contains(employee)) {

getProfessors().add(employee);

}

if (!employee.getProjects().contains(this)) {

employee.getProjects().add(this);

}

}

public String toString() {

return getClass().getName().substring(getClass().getName().lastIndexOf(".")+1) +

" no: " + getId() +

", name: " + getName();

}

}下载 Query_Distinct_Join_Condition.zip

以下是数据库转储。Table Name: ADDRESS

Row:

Column Name: ID,

Column Type: INTEGER:

Column Value: 0

Column Name: CITY,

Column Type: VARCHAR:

Column Value: null

Column Name: STATE,

Column Type: VARCHAR:

Column Value: BC

Column Name: STREET,

Column Type: VARCHAR:

Column Value: null

Column Name: ZIP,

Column Type: VARCHAR:

Column Value: null

Table Name: DEPARTMENT

Row:

Column Name: ID,

Column Type: INTEGER:

Column Value: 1

Column Name: NAME,

Column Type: VARCHAR:

Column Value: Design

Table Name: PHONE

Row:

Column Name: ID,

Column Type: BIGINT:

Column Value: 1

Column Name: NUMBER,

Column Type: VARCHAR:

Column Value: 111-111-1111

Column Name: TYPE,

Column Type: VARCHAR:

Column Value: null

Column Name: EMPLOYEE_ID,

Column Type: INTEGER:

Column Value: 0

Table Name: PROFESSOR

Row:

Column Name: ID,

Column Type: INTEGER:

Column Value: 0

Column Name: NAME,

Column Type: VARCHAR:

Column Value: TOM

Column Name: SALARY,

Column Type: BIGINT:

Column Value: 1111

Column Name: STARTDATE,

Column Type: DATE:

Column Value: null

Column Name: ADDRESS_ID,

Column Type: INTEGER:

Column Value: 0

Column Name: DEPARTMENT_ID,

Column Type: INTEGER:

Column Value: 1

Column Name: MANAGER_ID,

Column Type: INTEGER:

Column Value: null

Table Name: PROJECT

Table Name: PROJECT_PROFESSOR

转载地址:http://yznva.baihongyu.com/

你可能感兴趣的文章
《Total Commander:万能文件管理器》——第3.5节.选择文件
查看>>
《日志管理与分析权威指南》一导读
查看>>
去 TMD 互联网思维,性价比而已
查看>>
如何手动删除Oracle 11g数据库
查看>>
懒人促进社会进步 - 5种索引的原理和优化Case (btree,hash,gin,gist,brin)
查看>>
《深入实践Spring Boot》一3.4 视图设计
查看>>
《设计模式解析(第2版•修订版)》目录—导读
查看>>
《Web前端开发精品课 HTML与CSS进阶教程》——2.2 标题语义化
查看>>
Java核心技术卷I基础知识3.5.3 强制类型转换
查看>>
可与Mirai比肩的恶意程序Hajime,竟是为了保护IoT设备?
查看>>
《Spring Data 官方文档》6. Cassandra 存储库
查看>>
聊聊并发(十)生产者消费者模式
查看>>
R语言数据挖掘2.2.4.2 FP-growth算法
查看>>
人工智能概念诞生60年,哪些大牛堪称“一代宗师”?
查看>>
《游戏大师Chris Crawford谈互动叙事》一9.5 真实案例
查看>>
Mybatis与Spring整合连接MySQL
查看>>
GCC知识
查看>>
实验4 IIC通讯与EEPROM接口
查看>>
几个smarty小技巧
查看>>
Cocos2d-x3.2 Grid3D网格动作
查看>>