本文内容
- OID查询
- 对象导航查询
- HQL查询
- QBC查询
- SQL查询
首发日期:2019-11-6
hibernate的查询方式:
hibernate有很多查询方式
- OID查询
- 对象导航查询:
- HQL查询:
- QBC查询:
- SQL查询:
OID查询:
OID查询:基于唯一标识属性(主键)来查询
- 使用方法:session.get(持久类.class,主键值)或session.load(持久类.class,主键值)
public void test1() {
Configuration cfg = new Configuration().configure();
SessionFactory factory = cfg.buildSessionFactory();
Session session = factory.openSession();
Person p1 = session.get(Person.class, 1L);//因为我用的是Long,所以这里给个1L
Person p2 = session.load(Person.class, 2L);//不会立即发生sql语句
System.out.println(p1);
System.out.println(p2);//这里才发送p2的查询
}
get和load的区别:
load是延迟加载的,意思是当调用load的时候,并不立即发送SQL语句,只有当使用了这个对象的时候才去发送SQL语句。
而且,get对于不存在的对象的查询返回的是null,load会报错。
对象导航查询:利用对象之间的关系来获取【前提--对象之间建立了关系,比如给某个学生选择了班级,那么就可以通过这个学生来查询到班级,而无法通过这个学生查询到没有跟他绑定的班级】
public void test2() {
Configuration cfg = new Configuration().configure();
SessionFactory factory = cfg.buildSessionFactory();
Session session = factory.openSession();
Student student = session.get(Student.class, 1L);
Grade grade = student.getGrade();
System.out.println(grade);
Grade grade2 = session.get(Grade.class, 1L);
for (Student s : grade2.getStudents()) {
System.out.println(s);
}
}</span></pre><div class="cnblogs_code_toolbar"><span class="cnblogs_code_copy"><a href="javascript:void(0);" onclick="copyCnblogsCode(this)" title="复制代码"><img src="//common.cnblogs.com/images/copycode.gif" alt="复制代码"></a></span></div></div>
public void test3() {
Configuration cfg = new Configuration().configure();
SessionFactory factory = cfg.buildSessionFactory();
Session session = factory.openSession();
Query query = session.createQuery("from Student ");
List<Student> list = query.list();
for(Student s :list) {
System.out.println(s);
}
}</span></pre><div class="cnblogs_code_toolbar"><span class="cnblogs_code_copy"><a href="javascript:void(0);" onclick="copyCnblogsCode(this)" title="复制代码"><img src="//common.cnblogs.com/images/copycode.gif" alt="复制代码"></a></span></div></div>