Hibernate之hql中关联查询与with的用法

Hibernate以面向对象的方式提供我们查询,但是在很多复杂的多表查询中,hql或者sql方式查询就显得尤为重要!

实体类:Student

package com.tz.hql;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.ManyToOne;
import javax.persistence.Table;

@Entity
@Table(name = "tz_student")
public class Student implements java.io.Serializable{

	private static final long serialVersionUID = 1L;
	private Integer id;
	private String name;
	private String password;
	private ClassRoom classRoom;
	
	@Id
	@GeneratedValue(strategy=GenerationType.IDENTITY)
	public Integer getId() {
		return id;
	}

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

	@Column(name="name")
	public String getName() {
		return name;
	}

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

	@Column(name="password")
	public String getPassword() {
		return password;
	}

	public void setPassword(String password) {
		this.password = password;
	}

	@ManyToOne(targetEntity=ClassRoom.class,fetch=FetchType.LAZY)
	public ClassRoom getClassRoom() {
		return classRoom;
	}

	public void setClassRoom(ClassRoom classRoom) {
		this.classRoom = classRoom;
	}


	
}

实体:ClassRoom

package com.tz.hql;

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

import javax.persistence.Column;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.OneToMany;
import javax.persistence.Table;
import javax.persistence.Entity;

@Entity
@Table(name = "tz_class_room")
public class ClassRoom implements java.io.Serializable {

	private static final long serialVersionUID = 1L;
	private Integer id;
	private String name;
	private String departmentName;
	private List<Student> students = new ArrayList<Student>(0);

	@Id
	@GeneratedValue(strategy = GenerationType.IDENTITY)
	public Integer getId() {
		return id;
	}

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

	@Column(name = "name")
	public String getName() {
		return name;
	}

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

	@Column(name = "department_name")
	public String getDepartmentName() {
		return departmentName;
	}

	public void setDepartmentName(String departmentName) {
		this.departmentName = departmentName;
	}

	@OneToMany(targetEntity=Student.class,mappedBy="classRoom")
	public List<Student> getStudents() {
		return students;
	}

	public void setStudents(List<Student> students) {
		this.students = students;
	}

}

下面编写测试类:

package com.tz.hql;

import java.util.List;

import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
import org.hibernate.cfg.Configuration;
import org.hibernate.service.ServiceRegistry;
import org.junit.Test;

import com.sun.javafx.collections.MappingChange.Map;

public class HqlTest {

	@Test
	public void handle() {
		Configuration configuration = new Configuration().configure("hibernate.cfg.xml");
		ServiceRegistry serviceRegistry = new StandardServiceRegistryBuilder()
				.applySettings(configuration.getProperties()).build();
		SessionFactory sessionFactory = configuration.buildSessionFactory(serviceRegistry);
		Session session = sessionFactory.openSession();
//		String hql = "from Student";
//		Query query = session.createQuery(hql);
//		List<Student> list = query.list();
//		for(Student student:list){
//			System.out.println(student.getName());
//		}
		/*String sql = "select s.id as id,s.name as name,s.password as password from Student s";
		Query query = session.createQuery(sql);
		List<Student> list = query.list();
		System.out.println(list);*/
		
		String hql = "from Student s left join s.classRoom c with (c.id=1)";
		Query query = session.createQuery(hql);
		List<Student> list = query.list();
		System.out.println(list);
		
		/*String sql = "select new Map(s.id as id,s.name as name,s.password as password ) from Student s left  where  s.id=1 and s.name='keke'";
		Query query = session.createQuery(sql);
		List<Map<String,Object>> list = query.list();
		System.out.println(list);*/
		
		
	}
}

特别注意的是:关联查询的条件用with,其他查询的条件则用where,如测试类中最下面的返回List<Map>方式的查询。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值