以班级Classes和学生Student为例:
//内链接,两种方式效果一样,查询的是两边都有的数据 SELECT c.,s. FROM classes c,student s WHERE s.cid=c.cid;
SELECT c.cname,s.sname FROM classes c INNER JOIN student s ON s.cid=c.cid;
//左外连接,在内链接基础上,左边表有而右边表没有,两种方式等效; SELECT c.* ,s.* FROM student s LEFT OUTER JOIN classes c ON s.cid=c.cid; SELECT c.* ,s.* FROM student s LEFT JOIN classes c ON s.cid=c.cid;
//右外连接,在内链接基础上,右边有而左边无,两种方式等效; SELECT c.* ,s.* FROM classes c RIGHT OUTER JOIN student s ON s.cid=c.cid; SELECT c.* ,s.* FROM classes c RIGHT JOIN student s ON s.cid=c.cid;
//查询所有: from Classes c,Student s where c.cid=s.classes.cid; //选择某些属性查询 select c.cname,s.sname from Classes c,Student s where c.cid=s.classes.cid; //选择某些属性,封装为bean查询; select new cn.chen.system.model.ClassVsStudent(c.cname,s.sname) from Classes c,Student s where c.cid=s.cid; //内链接查询,得到的是两个bean from Classes c inner join c.students s; //内敛链接查询,得到的是Classes对象,对象中包含studet集合 from Classes c inner join fetch c.students s;
from Student s inner join fetch s.classes c;
select new cn.chen.system.model.ClassVsStudent(c.cname,s.sname) from Student s inner join s.classes c ;
from Classes c left outer join fetch c.students s;
from Student s left outer join fetch s.classes;
学生Student和课程Course为例: Student里有装Course的set集合,Course里也有装Student的set集合; 多对多与一对多操作差不多
/** * 1.得到所有的学生以及其对应的课程 * 从学生端出发 * list装的是学生; */ @Test public void testManyToMany_LeftJoin_Fecth(){ Session session = sessionFactory.openSession(); StringBuffer buffer = new StringBuffer(); buffer.append( "from Student s left outer join fetch s.courses"); Query query = session.createQuery(buffer.toString()); List list = query.list(); session.close(); } /** * 2.得到所有的课程及课程下对应的学生; * list装的是课程 */ @Test public void testManyToMany_LeftJoin_Fecth_2(){ Session session = sessionFactory.openSession(); StringBuffer buffer = new StringBuffer(); buffer.append( "from Course c left outer join fetch c.students s"); Query query = session.createQuery(buffer.toString()); query.list(); session.close(); } /** * 3.一对多和多对多的结合 * 得到所有班级下的所有学生以及所有学生下的所有课程; * 从班级出发 */ @Test public void testManyToManyAndOneToMany(){ Session session = sessionFactory.openSession(); StringBuffer buffer = new StringBuffer(); buffer.append( "from Classes c left outer join fetch" + " c.students s left outer join fetch s.courses"); Query query = session.createQuery(buffer.toString()); List<Classes> classeList = query.list(); //去掉集合中的重复元素 Set<Classes> sets = new HashSet<Classes>(classeList); classeList = new ArrayList<Classes>(sets); System. out.println(classeList.size()); for(Classes classes:classeList){//遍历班级 System. out.println(classes.getCname()); Set<Student> students = classes.getStudents();//得到班级下的学生 for(Student student:students){//遍历学生 System. out.println(student.getSname()); Set<Course> courses = student.getCourses(); for(Course course:courses){//遍历学生下的课程 System. out.println(course.getCname()); } } } session.close(); } /** * 从中间表出发,班级有学生,学生修课程,故从学生角度出发进行查询; */ @Test public void testManyToManyAndOneToMany_2(){ Session session = sessionFactory.openSession(); StringBuffer buffer = new StringBuffer(); buffer.append( "from Student s left outer join fetch s.classes c left outer join fetch s.courses cc"); Query query = session.createQuery(buffer.toString()); List<Student> studentList = query.list(); for(Student student:studentList){ System. out.println(student.getSname()); Classes classes = student.getClasses(); System. out.println(classes.getCname()); Set<Course> courses = student.getCourses(); for(Course course:courses){ System. out.println(course.getCname()); } } session.close(); } /*******************************************************************************/ /** * 面向对象的查询 */ @Test public void testQueryCriteria(){ Session session = sessionFactory.openSession(); List<Classes> classesList = session.createCriteria(Classes.class).list() ; System. out.println(classesList.size()); session.close(); } @Test public void testQueryCriteria_Where(){ Session session = sessionFactory.openSession(); Classes classes = (Classes)session.createCriteria(Classes.class).add(Restrictions.eq("cid" , 1L)).uniqueResult(); System. out.println(classes.getCname()); session.close(); } }