用Set中元素做条件查询

时间:2023-03-09 20:25:14
用Set中元素做条件查询

  一个老师教许多学生,一个学生被许多老师教,一个学生有好多书,同一种书被许多同学拥有。查询教拥有书"a"的学生的老师:
 
   class teacher{
 
   String id;
 
   String name;
 
   Set students;
 
   }
 
   class student{
 
   String id;
 
   String name;
 
   Set teachers;
 
   Set books;
 
   }
 
   class book{
 
   String id;
 
   String name;
 
   Set students;
 
   }
 
   利用连表的方法查询:
 
   SELECT t FROM teacher t join t.students s join s.books b where b.name = 'a'
 
   利用子查询(需要数据库支持子查询,mysql就不行)
 
   SELECT t FROM Teacher t,Student s,Book b where s.id in elements(t.students) and b.id in elements(s.books)
 
   另外t.students s中s并不是集合的意思,而是t的students对象的表别名,join t.students s这个hql,hibernate会翻译成两个表的内连接关系
 
   另一篇文章
 
   在Hibernate中类型为Set、List的实体属性也是可以连接查询的,例如User里面有一个Set knowledge属性要获取User中Knowledge的isShared的属性为true的User并且在返回的User中的knowledges中包含isShared为true的Knowledge对象的时候,就要通Set的过虑查询(左连接查询),在hibernate3.2.3以后的写法如下 www.lefeng123.com
 
   select distinct u from User u left join fetch u.knowledges k where k.isShare=true.
 
   这样就只会获取knowledge的isShared为true的User,并且User里面的knowleges中包含knowledge的isShared为true的Knowlege对象。
 
   需要注意的是:关键字distinct和fetch.要实现上面的数据过虑就得要这两个关键字。第一个关键字是独立的意思,第二个关键字是以一条sql语句执行。如果少了fetch这个关键字,则达不到目的。返回的结果是一个User包含isShared为true和false的knowledge集合托福答案 www.yztrans.com
 
   个人使用
 
   select js from edu.dzu.ksap.entity.JsBean js inner join js.xyBeans xy where xy.xydm=:xydm order by id
 
   JsBean为教室信息,XyBean为学院信息。学院--可使用教室的关系,为,但Xy为前期开发的模块,教室管理为新添加功能,Xy
 
   Bean不便于修改,当同学Xybean主键查询教室的信息时,可通过上面的HQL语句执行查询。需注意,由于为连表,需要select js,否则查找的对象不能转化为JsBean对象,即抛出java.lang.ClassCastException.