各种关联映射的实例

前端之家收集整理的这篇文章主要介绍了各种关联映射的实例前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

代码

1.Hibernate框架配置文件

hibernate.cfg.xml(连接数据库和实体类对应数据库表的配置文件)

<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
          "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
          "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

<!-- Generated by MyEclipse Hibernate Tools.                   -->
<hibernate-configuration>

<session-factory>
	<property name="show_sql">true</property>
	<property name="myeclipse.connection.profile">bookshop</property>
	<property name="connection.url">
		jdbc:MysqL://localhost:3306/bookshop
	</property>
	<property name="connection.username">root</property>
	<property name="connection.password">1234</property>
	<property name="connection.driver_class">
		com.MysqL.jdbc.Driver
	</property>
	<property name="dialect">
		org.hibernate.dialect.MysqLDialect
	</property>
	<mapping resource="com/hibtest2/entity/Users.hbm.xml" />
	<mapping resource="com/hibtest2/entity/Books.hbm.xml" />
	<mapping resource="com/hibtest2/entity/Publishers.hbm.xml" />
	<mapping resource="com/hibtest2/entity/Student.hbm.xml" />
	<mapping resource="com/hibtest2/entity/Course.hbm.xml" />

</session-factory>

</hibernate-configuration>

2.基类

BaseHibernateDAO.java

package com.hibtest2.dao;

import java.io.Serializable;
import java.util.List;

import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.hibernate.Transaction;
import org.hibernate.criterion.Example;

import com.hibtest2.HibernateSessionFactory;
public abstract class BaseHibernateDAO {
  /*
   * 添加数据
   */
	protected void add(Object object){
		Transaction tran=null;
		//获取session
		Session session=HibernateSessionFactory.getSession();
		try{
			//开始事务
			tran=session.beginTransaction();
			//持久化操作
		    session.save(object);
		    //提交事务
		    tran.commit();
		}catch (Exception e) {
			if(tran!=null){
				//事务回滚
				tran.rollback();
			}
			e.printStackTrace();
		}finally{
			//关闭session
			session.close();
		}		
	}
	
	/*
	 * 加载数据
	 */
	protected Object get(Class cla,Serializable id){
		Object object=null;
		Session session=HibernateSessionFactory.getSession();
		try {
			object=session.get(cla,id);
		} catch (HibernateException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		finally {
			session.close();
		}
		return object;
	}
	
	/*
	 * 删除数据
	 */
	
	protected void delete(Object object){
		Transaction tran=null;
		Session session=HibernateSessionFactory.getSession();
		try {
			tran=session.beginTransaction();
			session.delete(object);
			tran.commit();
		} catch (HibernateException e) {
			// TODO Auto-generated catch block
			if(tran!=null){
				tran.rollback();
			}
			e.printStackTrace();
		}
		finally {
			session.close();
		}
	}
	
	/*
	 * 修改数据
	 */
	protected void update(Object object){
		Transaction tran=null;
		Session session=HibernateSessionFactory.getSession();
		try {
			tran=session.beginTransaction();
			session.update(object);
			tran.commit();
		} catch (HibernateException e) {
			// TODO Auto-generated catch block
			if(tran!=null){
				tran.rollback();
			}
			e.printStackTrace();
		}
		finally {
			session.close();
		}
	}
	
	/*
	 * 查询数据
	 */
	protected List search(Class cla,Object condition){
		Session session=null;
		List list=null;
		try {
			session=HibernateSessionFactory.getSession();
			list=session.createCriteria(cla).add(Example.create(condition)).list();
		} catch (Exception e) {
			// TODO: handle exception
		} finally{
			session.close();
		}
		return list;		
	}	
}

3.实体类

Users.java

package com.hibtest2.entity;

/**
 * Users entity. @author MyEclipse Persistence Tools
 */

public class Users implements java.io.Serializable {

	// Fields

	private Integer id;
	private String loginName;
	private String loginPwd;

	// Constructors

	/** default constructor */
	public Users() {
	}

	/** full constructor */
	public Users(String loginName,String loginPwd) {
		this.loginName = loginName;
		this.loginPwd = loginPwd;
	}

	// Property accessors

	public Integer getId() {
		return this.id;
	}

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

	public String getLoginName() {
		return this.loginName;
	}

	public void setLoginName(String loginName) {
		this.loginName = loginName;
	}

	public String getLoginPwd() {
		return this.loginPwd;
	}

	public void setLoginPwd(String loginPwd) {
		this.loginPwd = loginPwd;
	}

}

Student.java

package com.hibtest2.entity;

import java.util.HashSet;
import java.util.Set;

/**
 * Student entity. @author MyEclipse Persistence Tools
 */

public class Student implements java.io.Serializable {

	// Fields

	private Integer studentId;
	private String studentName;
	private Set courses=new HashSet();

	// Constructors

	public Set getCourses() {
		return courses;
	}

	public void setCourses(Set courses) {
		this.courses = courses;
	}

	/** default constructor */
	public Student() {
	}

	/** full constructor */
	public Student(String studentName) {
		this.studentName = studentName;
	}

	// Property accessors

	public Integer getStudentId() {
		return this.studentId;
	}

	public void setStudentId(Integer studentId) {
		this.studentId = studentId;
	}

	public String getStudentName() {
		return this.studentName;
	}

	public void setStudentName(String studentName) {
		this.studentName = studentName;
	}

}

Publishers.java

package com.hibtest2.entity;

import java.util.HashSet;
import java.util.Set;

/**
 * Publishers entity. @author MyEclipse Persistence Tools
 */

public class Publishers implements java.io.Serializable {

	// Fields

	private Integer id;
	private String name;
	private Set bks=new HashSet();

	// Constructors

	public Set getBks() {
		return bks;
	}

	public void setBks(Set bks) {
		this.bks = bks;
	}

	/** default constructor */
	public Publishers() {
	}

	/** full constructor */
	public Publishers(String name) {
		this.name = name;
	}

	// Property accessors

	public Integer getId() {
		return this.id;
	}

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

	public String getName() {
		return this.name;
	}

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

}

Course.java

package com.hibtest2.entity;

import java.util.HashSet;
import java.util.Set;

/**
 * Course entity. @author MyEclipse Persistence Tools
 */

public class Course implements java.io.Serializable {

	// Fields

	private Integer courseId;
	private String courseName;
	private Set students=new HashSet();

	// Constructors

	public Set getStudents() {
		return students;
	}

	public void setStudents(Set students) {
		this.students = students;
	}

	/** default constructor */
	public Course() {
	}

	/** full constructor */
	public Course(String courseName) {
		this.courseName = courseName;
	}

	// Property accessors

	public Integer getCourseId() {
		return this.courseId;
	}

	public void setCourseId(Integer courseId) {
		this.courseId = courseId;
	}

	public String getCourseName() {
		return this.courseName;
	}

	public void setCourseName(String courseName) {
		this.courseName = courseName;
	}

}

Books.java

package com.hibtest2.entity;

/**
 * Books entity. @author MyEclipse Persistence Tools
 */

public class Books implements java.io.Serializable {

	// Fields

	private Integer id;
	private String title;
	private String author;
	//private Integer publisherId;
	private Publishers publishers;
	public Publishers getPublishers() {
		return publishers;
	}

	public void setPublishers(Publishers publishers) {
		this.publishers = publishers;
	}

	private Integer publisherDate;
	private String isbn;
	private Integer wordsCount;
	private Integer unitPrice;
	private String contentDescription;

	// Constructors

	/** default constructor */
	public Books() {
	}

	/** minimal constructor */
	public Books(String title,String author,Integer publisherId) {
		this.title = title;
		this.author = author;
		//this.publisherId = publisherId;
	}

	/** full constructor */
	public Books(String title,Integer publisherId,Integer publisherDate,String isbn,Integer wordsCount,Integer unitPrice,String contentDescription) {
		this.title = title;
		this.author = author;
		//this.publisherId = publisherId;
		this.publisherDate = publisherDate;
		this.isbn = isbn;
		this.wordsCount = wordsCount;
		this.unitPrice = unitPrice;
		this.contentDescription = contentDescription;
	}

	// Property accessors

	public Integer getId() {
		return this.id;
	}

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

	public String getTitle() {
		return this.title;
	}

	public void setTitle(String title) {
		this.title = title;
	}

	public String getAuthor() {
		return this.author;
	}

	public void setAuthor(String author) {
		this.author = author;
	}

	/*public Integer getPublisherId() {
		return this.publisherId;
	}

	public void setPublisherId(Integer publisherId) {
		this.publisherId = publisherId;
	}*/

	public Integer getPublisherDate() {
		return this.publisherDate;
	}

	public void setPublisherDate(Integer publisherDate) {
		this.publisherDate = publisherDate;
	}

	public String getIsbn() {
		return this.isbn;
	}

	public void setIsbn(String isbn) {
		this.isbn = isbn;
	}

	public Integer getWordsCount() {
		return this.wordsCount;
	}

	public void setWordsCount(Integer wordsCount) {
		this.wordsCount = wordsCount;
	}

	public Integer getUnitPrice() {
		return this.unitPrice;
	}

	public void setUnitPrice(Integer unitPrice) {
		this.unitPrice = unitPrice;
	}

	public String getContentDescription() {
		return this.contentDescription;
	}

	public void setContentDescription(String contentDescription) {
		this.contentDescription = contentDescription;
	}

}

4.实体类映射文件

Users.hbm.xml

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- 
    Mapping file autogenerated by MyEclipse Persistence Tools
-->
<hibernate-mapping>
    <class name="com.hibtest2.entity.Users" table="users" catalog="bookshop">
        <id name="id" type="java.lang.Integer">
            <column name="Id" />
            <generator class="native"></generator>
        </id>
        <property name="loginName" type="java.lang.String">
            <column name="LoginName" length="50" />
        </property>
        <property name="loginPwd" type="java.lang.String">
            <column name="LoginPwd" length="16" />
        </property>
    </class>
</hibernate-mapping>

Student.hbm.xml

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- 
    Mapping file autogenerated by MyEclipse Persistence Tools
-->
<hibernate-mapping>
    <class name="com.hibtest2.entity.Student" table="student" catalog="bookshop">
        <id name="studentId" type="java.lang.Integer">
            <column name="StudentId" />
            <generator class="native"></generator>
        </id>
        <property name="studentName" type="java.lang.String">
            <column name="StudentName" length="16" />
        </property>
        <set name="courses" table="sc" lazy="false" inverse="false">
   			<key column="Sid" not-null="true" />
			<many-to-many column="Cid" class="com.hibtest2.entity.Course" />
		</set>
        
    </class>
</hibernate-mapping>

Publishers.hbm.xml

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- 
    Mapping file autogenerated by MyEclipse Persistence Tools
-->
<hibernate-mapping>
    <class name="com.hibtest2.entity.Publishers" table="publishers" catalog="bookshop">
        <id name="id" type="java.lang.Integer">
            <column name="Id" />
            <generator class="native"></generator>
        </id>
        <property name="name" type="java.lang.String">
            <column name="Name" length="16" not-null="true" />
        </property>
        <set name="bks" lazy="false" cascade="all" inverse="true">
			<key column="PublisherId" not-null="true"/>
			<one-to-many class="com.hibtest2.entity.Books"/>
		</set>        
    </class>
</hibernate-mapping>

Course.hbm.xml

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- 
    Mapping file autogenerated by MyEclipse Persistence Tools
-->
<hibernate-mapping>
    <class name="com.hibtest2.entity.Course" table="course" catalog="bookshop">
        <id name="courseId" type="java.lang.Integer">
            <column name="CourseId" />
            <generator class="native"></generator>
        </id>
        <property name="courseName" type="java.lang.String">
            <column name="CourseName" length="16" />
        </property>
        <set name="students" table="sc" lazy="false" inverse="true">
			<key column="Cid" not-null="true" />
  			<many-to-many column="Sid" class="com.hibtest2.entity.Student" />
		</set>
        
    </class>
</hibernate-mapping>

Books.hbm.xml

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- 
    Mapping file autogenerated by MyEclipse Persistence Tools
-->
<hibernate-mapping>
    <class name="com.hibtest2.entity.Books" table="books" catalog="bookshop">
        <id name="id" type="java.lang.Integer">
            <column name="Id" />
            <generator class="native"></generator>
        </id>
        <property name="title" type="java.lang.String">
            <column name="Title" length="16" not-null="true" />
        </property>
        <property name="author" type="java.lang.String">
            <column name="Author" length="16" not-null="true" />
        </property>
        <!-- 
        <property name="publisherId" type="java.lang.Integer">
            <column name="PublisherId" not-null="true" />
        </property>
         -->        
        <many-to-one name="publishers" column="PublisherId" class="com.hibtest2.entity.Publishers" insert="true" update="true" lazy="false"/>         
        <property name="publisherDate" type="java.lang.Integer">
            <column name="PublisherDate" />
        </property>
        <property name="isbn" type="java.lang.String">
            <column name="ISBN" length="16" />
        </property>
        <property name="wordsCount" type="java.lang.Integer">
            <column name="WordsCount" />
        </property>
        <property name="unitPrice" type="java.lang.Integer">
            <column name="UnitPrice" precision="8" scale="0" />
        </property>
        <property name="contentDescription" type="java.lang.String">
            <column name="ContentDescription" length="16" />
        </property>
    </class>
</hibernate-mapping>

5.各种关联映射示例

5.1多对一映射示例

package com.hibtest2;

import com.hibtest2.dao.BaseHibernateDAO;
import com.hibtest2.entity.Books;

public class TestManyToOne extends BaseHibernateDAO {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		TestManyToOne mto=new TestManyToOne();
		mto.testManyToOne();
	}
	public void testManyToOne(){
        //根据id获取Books对象
		Books books=(Books) super.get(Books.class,new Integer(4947));		
        //根据多对一映射,从Books对象中获取指定图书的出版社
		System.out.println("编号是4947的图书出版社是:"+books.getPublishers().getName().toString());		
	}


}

5.2一对多映射示例
package com.hibtest2;

import java.util.Iterator;

import com.hibtest2.dao.BaseHibernateDAO;
import com.hibtest2.entity.Books;
import com.hibtest2.entity.Publishers;

public class TestOneToMany extends BaseHibernateDAO {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		TestOneToMany otm=new TestOneToMany();
		otm.testOneToMany();
	}
	public void testOneToMany(){
        //根据id获取Publishers对象
		Publishers publishers=(Publishers) super.get(Publishers.class,new Integer(1));
		System.out.println(publishers.getName()+"出版社出版的图书包括:");
        //根据一对多映射,从Publishers对象中获取出版图书名称
		Iterator iter=publishers.getBks().iterator();
		while(iter.hasNext()){
			Books books=(Books)iter.next();
			System.out.println(books.getTitle());
		}
	}


}

5.3多对多映射示例
package com.hibtest2;

import java.util.Iterator;

import com.hibtest2.dao.BaseHibernateDAO;
import com.hibtest2.entity.Course;
import com.hibtest2.entity.Student;

public class TestManyToMany extends BaseHibernateDAO  {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		TestManyToMany m2m=new TestManyToMany();
		//m2m.testAdd_1();	
		//m2m.testAdd_2();
		//m2m.testAdd_3();
		//m2m.testDelete_1();
		m2m.testDelete_2();
	}
	
	public void testAdd_1(){
	   //创建两个Student对象
		Student s1=new Student();
		s1.setStudentName("韦小宝");		
		Student s2=new Student();
		s2.setStudentName("令狐冲");
		//创建四个Course对象
		Course c1=new Course();
		c1.setCourseName("数据结构");
		Course c2=new Course();
		c2.setCourseName("操作系统");
		Course c3=new Course();
		c3.setCourseName("计算机组成原理");
		Course c4=new Course();
		c4.setCourseName("离散数学");
		//设定s1与c1和c2之间的相互关联
		s1.getCourses().add(c1);
		s1.getCourses().add(c2);
		/*c1.getStudents().add(s1);
		c2.getStudents().add(s1);*/
		//设定s2与c1、c3和c4之间的相互关联
		s2.getCourses().add(c1);
		s2.getCourses().add(c3);
		s2.getCourses().add(c4);
		/*c1.getStudents().add(s2);
		c3.getStudents().add(s2);
		c4.getStudents().add(s2);*/
		//保存c1、c2、c3和c4
		super.add(c1);
		super.add(c2);
		super.add(c3);
		super.add(c4);
        //保存s1和s2对象
		super.add(s1);
		super.add(s2);
	}
	
	public void testAdd_2(){
		//创建"东方不败"对象
		Student newStu=new Student();
		newStu.setStudentName("东方不败");
	    //加载"计算机组成原理"对象
		Course c=(Course)super.get(Course.class,new Integer(3));		
	    //设置newStu和c对象之间的关联
		newStu.getCourses().add(c);		
		//保存对象newStu
		super.add(newStu);	
		//更新对象c
		super.update(c);
	}
	
	public void testAdd_3(){
		//加载"韦小宝"和"东方不败"对象
		Student wxb=(Student)super.get(Student.class,new Integer(1));
		Student dfbb=(Student)super.get(Student.class,new Integer(3));
	    //创建"编译原理"课程对象
		Course byyl=new Course();
		byyl.setCourseName("编译原理");
	    //设定wxb、dfbb与byyl对象之间的关联
		wxb.getCourses().add(byyl);
		dfbb.getCourses().add(byyl);
	    //保存byyl对象
		super.add(byyl);
	    //更新wxb和dfbb对象
		super.update(wxb);
		super.update(dfbb);
	}
	
	public void testDelete_1(){
		//加载"韦小宝"对象,并获得其选课集合
		Student student=(Student)super.get(Student.class,new Integer(1));
		Iterator courses=student.getCourses().iterator();
	    //删除中介表sc中与"韦小宝"关联的记录
		while(courses.hasNext()){
			Course course=(Course)courses.next();
			course.getStudents().remove(student);	
		}
	    //将"韦小宝"对象删除
		super.delete(student);
	}
	public void testDelete_2(){
		//加载"令狐冲"对象
		Student student=(Student)super.get(Student.class,new Integer(2));
		//将"令狐冲"对象删除
		super.delete(student);

	}
	
}

5.4双向关联映射示例
package com.hibtest2;

import com.hibtest2.dao.BaseHibernateDAO;
import com.hibtest2.entity.Books;
import com.hibtest2.entity.Publishers;

public class TestM2OAndO2M extends BaseHibernateDAO {

	/**
	 * 双向关联映射
	 */
	public static void main(String[] args) {
		TestM2OAndO2M m2o_o2m=new TestM2OAndO2M();
		//m2o_o2m.testAdd_1();
		//m2o_o2m.testAdd_2();
		//m2o_o2m.testAdd_3();
		//m2o_o2m.testAdd_4();
		//m2o_o2m.testDelete_1();
		//m2o_o2m.testDelete_2();
		m2o_o2m.testUpdate();
	}
	public void testAdd_1(){
        //添加出版社信息
		Publishers publishers=new Publishers();
		publishers.setName("电子工业出版社");
		super.add(publishers);		
	}
	public void testAdd_2(){		
	    //加载得到电子工业出版社实体对象
		Publishers dzgy=(Publishers)super.get(Publishers.class,new Integer(4));
		//新建图书对象
		Books book1=new Books();		
		book1.setTitle("单元测试之道C#版");
		book1.setAuthor("(美)托马斯等");
		//将电子工业出版社对象设置到实体对象Books的publishers属性中
		book1.setPublishers(dzgy);
		//将图书对象保存到数据库
		super.add(book1);	
		//新建图书对象
		Books book2=new Books();
		book2.setTitle("C++网络编程,卷1");
		book2.setAuthor("(美)施密特");
		//将电子工业出版社对象设置到实体对象Books的publishers属性中
		book2.setPublishers(dzgy);
		//将图书对象保存到数据库
		super.add(book2);	
	}

	public void testAdd_3(){
	    //创建水利水电出版社对象
		Publishers publishers=new Publishers();
		publishers.setName("水利水电出版社");
		//创建第一个Books对象
		Books book1=new Books();		
		book1.setTitle("二级C语言程序设计");
		book1.setAuthor("侯东昌,宋智玲等");	
	    //创建第二个Book对象			
		Books book2=new Books();
		book2.setTitle("Visual Basic.NET");
		book2.setAuthor("徐振明主编");		
		//建立Publishers对象和Books对象的一对多双向关联关系,
		//只需从Publishers一方进行维护即可
		publishers.getBks().add(book1);
		publishers.getBks().add(book2);
		//保存Publishers对象
		super.add(publishers);
	}
	
	public void testAdd_4(){
		//创建一个Publishers对象
    	Publishers publishers=new Publishers();
		publishers.setName("西安电子科技大学出版社");
		//创建两个Books对象
		Books book1=new Books();		
		book1.setTitle("Windows CE应用程序设计");
		book1.setAuthor("张勇,许波编著");
		Books book2=new Books();
		book2.setTitle("MATLAB及其在...");
		book2.setAuthor("陈怀琛 编著");
		//由于将关联关系交给Books来维护,所以在存储时必须明确地
	    //将Publishers设定给Books,即Books必须调用setPublishers()方法
		book1.setPublishers(publishers);
		book2.setPublishers(publishers);		
	    //建立Publishers对象和Books对象的一对多双向关联关系,并保存Publishers对象
		publishers.getBks().add(book1);
		publishers.getBks().add(book2);		
		super.add(publishers);
	}
	
	public void testDelete_1(){
		//加载待删除的Books对象
		Books book=(Books)super.get(Books.class,new Integer(4939));
	    //调用父类的delete方法删除对象
		super.delete(book);
	}
	
	public void testDelete_2(){
		//加载水利水电出版社对象
		Publishers publisher=(Publishers)super.get(Publishers.class,new Integer(5));
		super.delete(publisher);	
	}
	
	public void testUpdate(){
	    //加载"Windows CE应用程序设计"图书实体对象
		Books web_yykf=(Books)super.get(Books.class,new Integer(4958));
		//加载"西安电子科技大学出版社"和"机械工业出版社"两个出版社实体对象
	    Publishers xadz=(Publishers)super.get(Publishers.class,new Integer(6));
		Publishers jxgy=(Publishers)super.get(Publishers.class,new Integer(3));
		//从"西安电子科技大学出版社"对象的 bks属性删除图书"Windows CE应用程序设计",
		//并添加到"机械工业出版社"的bks属性中,同时将"机械工业出版社"设置到该图书对象中
	    xadz.getBks().remove(web_yykf);	
	    jxgy.getBks().add(web_yykf);
		web_yykf.setPublishers(jxgy);
	    //更新"Windows CE应用程序设计"图书对象
		super.update(web_yykf);
	}


}

5.5HQL查询示例
package com.hibtest2;

import java.util.Iterator;
import java.util.List;

import org.hibernate.Query;
import org.hibernate.Session;

import com.hibtest2.entity.Books;

public class TestHQL {

	/**
	 * HQL查询
	 */
	public static void main(String[] args) {
		TestHQL tHql=new TestHQL();
		//tHql.testHql_1();
		//tHql.testHql_2();
		//tHql.testHql_3();
		//tHql.testHql_4();
		//tHql.testHql_5();
		//tHql.testHql_6();
		//tHql.pagedSearch(2,3);
		tHql.testHql_7();
	}
	
	public void testHql_1(){
        //获取session
		Session session=HibernateSessionFactory.getSession();
        //编写HQL语句
		String hql="from Books";
        //创建Query对象
		Query query=session.createQuery(hql);
        //执行查询,获得结果
		List list=query.list();
		//遍历查找结果
		Iterator itor=list.iterator();
		while(itor.hasNext()){
			Books book=(Books)itor.next();
			System.out.println(book.getTitle()+" "+book.getAuthor()+" "+book.getContentDescription());
		}
	}
	
	/**
	 * 属性查询
	 */
	public void testHql_2(){
		Session session=HibernateSessionFactory.getSession();
		//编写HQL语句,使用属性查询
		String hql="select books.title,books.author from Books as books";
		Query query=session.createQuery(hql);
		List list=query.list();
		Iterator itor=list.iterator();
		//每天记录封装成一个Object数组
		while(itor.hasNext()){
			Object[] object=(Object[])itor.next();
			System.out.println(object[0]+"      "+object[1]);
		}
	}
	
	/**
	 * 参数查询,按参数位置查询
	 */
	public void testHql_3(){
		Session session=HibernateSessionFactory.getSession();
		//编写HQL语句,使用参数查询
		String hql="from Books books where books.title like ? ";
		Query query=session.createQuery(hql);
		//给HQL语句中“?”代表的参数设置值
		query.setString(0,"%C++%");
		List list=query.list();
		Iterator itor=list.iterator();
		while(itor.hasNext()){
			Books book=(Books)itor.next();
			System.out.println(book.getTitle()+"      "+book.getAuthor()+"       "+book.getContentDescription());
		}
	}

	/**
	 * 参数查询,按参数名字查询
	 */
	public void testHql_4(){
		Session session=HibernateSessionFactory.getSession();
		//通过":bookTitle"定义命名参数"bookTitle"
		String hql="from Books books where books.title=:bookTitle";
		Query query=session.createQuery(hql);
		//给命名参数设置值
		query.setString("bookTitle","C++ Primer中文版");
		List list=query.list();
		Iterator itor=list.iterator();
		while(itor.hasNext()){
			Books book=(Books)itor.next();
			System.out.println(book.getTitle()+"      "+book.getAuthor()+"       "+book.getContentDescription());
		}
	}
	
	/**
	 * 连接查询
	 */
	public void testHql_5(){
		Session session=HibernateSessionFactory.getSession();
		//编写HQL语句,使用连接查询
		String hql="select b from Books b,Publishers p where b.publishers=p and p.name='清华大学出版社'";
		Query query=session.createQuery(hql);
		List list=query.list();
		Iterator itor=list.iterator();
		while(itor.hasNext()){
			Books book=(Books)itor.next();
			System.out.println(book.getTitle()+"      "+book.getAuthor()+"       "+book.getContentDescription());
		}
	}
	
	/**
	 * 分页查询
	 */
	public void testHql_6(){
		Session session=HibernateSessionFactory.getSession();
		//按书名升序查询图书对象
		String hql="from Books b order by b.title asc";
		Query query=session.createQuery(hql);
		//从第一个对象开始查询
		query.setFirstResult(0);
		//从查询结果中一次返回3个对象
		query.setMaxResults(3);
		//执行查询
		List list=query.list();
		//遍历查询结果
		Iterator itor=list.iterator();
		while(itor.hasNext()){
			Books book=(Books)itor.next();
			System.out.println(book.getTitle()+"      "+book.getAuthor()+"       "+book.getContentDescription());
		}
	}	
	
public void pagedSearch(int pageIndex,int pageSize){
	Session session=HibernateSessionFactory.getSession();
	String hql="from Books b order by b.title asc";
	Query query=session.createQuery(hql);
	int startIndex=(pageIndex-1)*pageSize;
	query.setFirstResult(startIndex);
	query.setMaxResults(pageSize);
	List list=query.list();
	Iterator itor=list.iterator();
	while(itor.hasNext()){
		Books book=(Books)itor.next();
		System.out.println(book.getTitle()+"      "+book.getAuthor()+"       "+book.getContentDescription());
	}
}
	
	/**
	 * 聚集函数
	 */
	public void testHql_7(){
		Session session=HibernateSessionFactory.getSession();
		//统计记录总数
		String hql1="select count(b) from Books b";
		Query query1=session.createQuery(hql1);
		Long count=(Long)query1.uniqueResult();		
		//统计书的平均金额
		String hql2="select avg(b.unitPrice) from Books b";
		Query query2=session.createQuery(hql2);
		Double money=(Double)query2.uniqueResult();	
		//统计最贵和最便宜的图书
		String hql3="select min(b.unitPrice),max(b.unitPrice) from Books b";
		Query query3=session.createQuery(hql3);
		Object[] price=(Object[])query3.uniqueResult();
		System.out.println("记录总数"+count.toString()+"  平均金额"+
				money.toString()+"  书价最低为"+price[0].toString()+
				"  书价最高为"+price[1].toString());		
	}



}

5.6Criteria查询示例
package com.hibtest2;

import java.util.*;
import org.hibernate.*;
import org.hibernate.criterion.*;
import com.hibtest2.entity.Books;

public class TestCriteria {

	/**
	 * Criteria查询
	 */
	public static void main(String[] args) {
		TestCriteria tc=new TestCriteria();	
		
		//使用对象封装查询条件
		/*Books books=new Books();
		books.setTitle("Web应用");  
		tc.testCriteria_1(books);*/
		
		//tc.testCriteria_2();		
	    //tc.testCriteria_2_1();
		//tc.testCriteria_3();
		//tc.testCriteria_4();
		
		tc.testDetachedCriteria();

	}
	/**
	 * 使用Criteria对象进行简单查询
	 * @param condition
	 */
	public void testCriteria_1(Books condition){
		//获得session
		Session session=HibernateSessionFactory.getSession();
		//创建Criteria对象
		Criteria criteria=session.createCriteria(Books.class);
		//使用Restrictions对象编写查询条件,并将查询条件加入Criteria对象
		if(condition!=null){			
			if(condition.getTitle()!=null && !condition.getTitle().equals("")){
				//按书名进行筛选
				criteria.add(Restrictions.like("title",condition.getTitle(),MatchMode.ANYWHERE));
			}
			if(condition.getAuthor()!=null && !condition.getAuthor().equals("")){
				//按作者进行筛选
				criteria.add(Restrictions.like("author",condition.getAuthor(),MatchMode.ANYWHERE));
			}
		}
		//排序
		criteria.addOrder(Order.asc("id"));
		//执行查询,获得结果
		List list=criteria.list();
		//遍历查询结果
		Iterator itor=list.iterator();
		while(itor.hasNext()){
			Books book=(Books)itor.next();
			System.out.println(book.getTitle()+"      "+book.getAuthor()+"       "+book.getContentDescription());
		}
	}
	
	/**
	 * 使用Criterion 并通过 Restrictions 工具类,实现关联查询
	 */
	public void testCriteria_2(){
		Session session=HibernateSessionFactory.getSession();
		Criteria bookCriteria=session.createCriteria(Books.class);
		//设置从Books类中查询的条件
		bookCriteria.add(Restrictions.like("title","C++",MatchMode.ANYWHERE));
		//创建一个新的Criteria实例,以引用pulishers集合中的元素
		Criteria publishersCriteria=bookCriteria.createCriteria("publishers");
		//设置从关联的Publishers类中查询的条件
		publishersCriteria.add(Restrictions.like("name","清华大学出版社"));
		List list=publishersCriteria.list();
		Iterator itor=list.iterator();
		while(itor.hasNext()){
			Books book=(Books)itor.next();
			System.out.println(book.getTitle()+"      "+book.getAuthor()+"       "+book.getContentDescription());
		}
	}
	
	/**
	 * 采用方法链编程风格,使用Criteria对象进行查询
	 */
	public void testCriteria_2_1(){
		Session session=HibernateSessionFactory.getSession();
		List list=session.createCriteria(Books.class)
		.add(Restrictions.like("title",MatchMode.ANYWHERE))
		.createCriteria("publishers")
		.add(Restrictions.like("name","清华大学出版社")).list();
		Iterator itor=list.iterator();
		while(itor.hasNext()){
			Books book=(Books)itor.next();
			System.out.println(book.getTitle()+"      "+book.getAuthor()+"       "+book.getContentDescription());
		}
	}
	
	/**
	 * 使用Criterion 并通过 Restrictions 工具类,实现分页查询
	 */
	public void testCriteria_3(){
		Session session=HibernateSessionFactory.getSession();
		Criteria criteria=session.createCriteria(Books.class);
		//从第一个对象开始查询
		criteria.setFirstResult(0);
		//每次从查询结果中返回4个对象
		criteria.setMaxResults(4);
		List list=criteria.list();
		Iterator itor=list.iterator();
		while(itor.hasNext()){
			Books book=(Books)itor.next();
			System.out.println(book.getTitle()+"      "+book.getAuthor()+"       "+book.getContentDescription());
		}
	}
	
	/**
	 * 使用Expression类实现查询
	 */
	public void testCriteria_4(){
		Session session=HibernateSessionFactory.getSession();
		List list=session.createCriteria(Books.class)
		//使用Expression类编写查询条件
		.add(Expression.like("title",MatchMode.ANYWHERE))
		//对查询结果进行排序
		.addOrder(Order.asc("id")).list();
		Iterator itor=list.iterator();
		while(itor.hasNext()){
			Books book=(Books)itor.next();
			System.out.println(book.getTitle()+"      "+book.getAuthor()+"       "+book.getContentDescription());
		}
	}
	
	/**
	 * 使用DetachedCriteria查询
	 */
	public void testDetachedCriteria(){
		//创建离线查询DetachedCriteria实例
		DetachedCriteria query=DetachedCriteria.forClass(Books.class)
		.add(Property.forName("title").eq("Web应用开发技术"));
		//创建Hibernate Session
		Session session=HibernateSessionFactory.getSession();
		//执行查询
		List list=query.getExecutableCriteria(session).list();
		Iterator itor=list.iterator();
		while(itor.hasNext()){
			Books book=(Books)itor.next();
			System.out.println(book.getTitle()+"      "+book.getAuthor()+"       "+book.getContentDescription());
		}
	}

}
总结:通过练习,基本了解Hibernate框架的运行原理,熟练掌握Hibernate框架的基本数据库操作。

猜你在找的XML相关文章