Session是持久层操作的基础,相当于JDBC中的Connection,通过Session会话来保存、更新、查找数据。
session是Hibernate运作的中心,对象的生命周期、事务的管理、数据库的存取都与Session有关
Session由SessionFactory创建,是线程安全的Thread-Safe,可以让多个线程同时存取SessionFactory
而不会有数据共享的问题

Hibernate中Session的解释 :http://blog.csdn.net/shrek_xu/article/details/740991
Hibernate 笔记 HQL查询(一)单属性,多属性查询 : http://www.cnblogs.com/zilong882008/archive/2011/11/05/2237123.html

1. hql的查询应用:

hibernate的session.createQuery()方法是使用HQL语句查询对象的。

hql:是查询对象的,例如:"from User",其中from不区分大小写,而User区分大小写,因为它是对象。是User类
返回Query对象。
执行这条语句后,Hibernate会根据配置文件中所配置的数据库适配器自动生成相应数据库的SQL语句。

sql: select * from dept; from 后面是表名
hql: form Dept; from 后面是

可以对类起别名,有两种方法。
hql: from Dept d
hql:from Dept as d

2. 查询表中单个属性
sql: select ename from dept
hql: select ename from Dept

对属性也可以设置别名
hql:select ename as from Dept
as 必须加。

3. 多属性查询

sql: select ename,eage from emp
hql: select ename,eage from Emp
hql: select e.ename,e.eage from Emp e

注意:对多个属性查询的时候,使用Obejct数组。

 //第三个查询:对多属性查询
Query query3=session.createQuery("select ename,eage from Emp");
List<Object[]> list3 = query3.list();
//对多个属性查询的时候,使用Obejct数组。
for(Object[] message:list3){
//采用辅助类Arrays的toString()方法打印数组。
System.out.println(Arrays.toString(message));
}

4. 通过实体类方式查询多属性

除了上述方法外,还可以采用实体类的方式查询,要在Emp类中加入带有查询参数的构造器,代码如下。

public class Emp {
private int eid;
private int eage;
private float esal;
private String ename;
省略get,set方法。 public Emp() {
super();
}
public Emp(int eage, String ename) { //需要查询的属性是什么,构造器的参数就是什么。
super();
this.eage = eage;
this.ename = ename;
}

查询代码:

Query query=session.createQuery("select new Emp(eage,ename) from Emp e");    
//select 后直接调用构造器,参数就是查询的属性,参数不可错乱。
List<Emp> list = query.list(); //此处不实用object数组,类类型即可
for(Emp message:list){
System.out.print("姓名:"+message.getEname()+" ");
System.out.println("年龄:"+message.getEage());
}

5.Criteria Query (功能和Query类似)

Hibernate学习笔记--Criteria Query :http://demojava.iteye.com/blog/858342

Criteria Query通过面向对象的设计,将数据查询条件封装为一个对象。

简单来说,Criteria Query可以看作是传统SQL的对象化表示,如:

//第五个查询
Criteria criteria=session.createCriteria(Emp.class);
criteria.add(Restrictions.like("did",1));
criteria.add(Restrictions.eq("eage", 30));
//相当于select eid,ename,eage from Emp where did=1 and eage=30
List<Emp> list5=criteria.list();
for(Emp em:list5){
System.out.println(em.getEid()+" "+em.getEname()+em.getEage());
}

本质上是对"select eid,ename,eage from Emp where did=1 and eage=30"的封装。

结果:1 乔峰 30

====

例子:

建表

在数据库ztest中建Dept表 在数据库ztest中建Emp表

create table DEPT
(
DID Integer NOT NULL PRIMARY KEY,
DNAME VARCHAR(12),
DADDRESS VARCHAR(12),
) create table EMP
(
EID INTEGER NOT NULL PRIMARY KEY,
ENAME VARCHAR(12),
EAGE INTEGER,
ESAL INTEGER,
DID INTEGER,
) insert into DEPT values(1,'业务部','address101')
insert into DEPT values(2,'技术部','address201')
insert into DEPT values(3,'管理部','address301')
insert into DEPT values(4,'财务部','address401')
insert into DEPT values(5,'人力资源部','address501') insert into EMP values(1,'乔峰',30,10000,1)
insert into EMP values(2,'杨过',25,15020,2)
insert into EMP values(3,'郭靖',33,23563,1)
insert into EMP values(4,'周伯通',52,32000,3)
insert into EMP values(5,'东方不败',43,12000,3)
insert into EMP values(6,'任我行',44,16000,4)
insert into EMP values(7,'任盈盈',30,22000,4)
insert into EMP values(8,'李莫愁',42,45000,5)
insert into EMP values(9,'令狐冲',35,20000,2)
insert into EMP values(10,'岳不群',50,42000,2)

进行查询

package com.hibernate.hql;

import java.util.Arrays;
import java.util.List; import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration; public class Test {
public static void main(String[] args){
try {
Test1() ;
} catch (Exception e) {
e.printStackTrace();
}
}
public static void Test1() throws Exception{
Configuration config=new Configuration().configure();
SessionFactory sessionFactory= config.buildSessionFactory();
Session session=null;
Transaction tr=null;
try{
session= sessionFactory.openSession();
tr=session.beginTransaction(); //第一个查询
String hql="from Dept"; //定义String类型hql,写入hql语句。
Query query=session.createQuery(hql);
List<Dept> list = query.list(); for(Dept dept:list){
System.out.print("部门编号: "+dept.getDid() +" ");
System.out.println("部门名称: "+dept.getDname());
} //第二个查询
String hql2 = "from Emp where eid = 5";
Query query2 = session.createQuery(hql2);
List<Emp> list2 = query2.list();
for(Emp emp:list2){
System.out.print("员工编号:"+emp.getEid());
System.out.println("员工姓名:"+emp.getEname());
} //第三个查询:对多属性查询
Query query3=session.createQuery("select ename,eage from Emp");
List<Object[]> list3 = query3.list();
//对多个属性查询的时候,使用Obejct数组。 for(Object[] message:list3){
//采用辅助类Arrays的toString()方法打印数组。
System.out.println(Arrays.toString(message));
} tr.commit();
}catch(Exception e){
tr.rollback();
}finally{
if(session!=null){
session.close();
}
if(sessionFactory!=null){
sessionFactory.close();
}
}
}
}

Hibernate学习笔记-Hibernate HQL查询的更多相关文章

  1. Hibernate学习笔记(十) — HQL查询

    一.HQL的一对多查询 班级(1)->(多)学生 /** * 实现Classes与Student的内连接 * * SELECT c.*,s.* * from classes c INNER JO ...

  2. HIbernate学习笔记5 之 查询

    一.HQL查询 * 按条件查询,条件中写的是属性名,之后在query对象为添加赋值,如: String hql = " from User where uid=?"; Sessio ...

  3. Hibernate学习笔记-Hibernate关系映射

    1. 初识Hibernate——关系映射 http://blog.csdn.net/laner0515/article/details/12905711 2. Hibernate 笔记8 关系映射1( ...

  4. Hibernate学习笔记--Hibernate框架错误集合及解决

    错误1:MappingException: Unknown entity解决方案 http://jingyan.baidu.com/article/e75aca8552761b142edac6cf.h ...

  5. Hibernate学习笔记(二)

    2016/4/22 23:19:44 Hibernate学习笔记(二) 1.1 Hibernate的持久化类状态 1.1.1 Hibernate的持久化类状态 持久化:就是一个实体类与数据库表建立了映 ...

  6. Hibernate学习笔记(一)

    2016/4/18 19:58:58 Hibernate学习笔记(一) 1.Hibernate框架的概述: 就是一个持久层的ORM框架. ORM:对象关系映射.将Java中实体对象与关系型数据库中表建 ...

  7. J2EE进阶(十七)Hibernate中常用的HQL查询方法(getHibernateTemplate())

    J2EE进阶(十七)Hibernate中常用的HQL查询方法(getHibernateTemplate())   当我们使用Hibernate进行数据的CRUD操作时,利用模版进行操作不失为一种方法. ...

  8. Hibernate 学习笔记一

    Hibernate 学习笔记一 今天学习了hibernate的一点入门知识,主要是配置domain对象和表的关系映射,hibernate的一些常用的配置,以及对应的一个向数据库插入数据的小例子.期间碰 ...

  9. MyBatis:学习笔记(3)——关联查询

    MyBatis:学习笔记(3)--关联查询 关联查询 理解联结 SQL最强大的功能之一在于我们可以在数据查询的执行中可以使用联结,来将多个表中的数据作为整体进行筛选. 模拟一个简单的在线商品购物系统, ...

随机推荐

  1. WebService实现文件上传下载

    一:服务端:一个普通java web工程 package com.wzh.file; import com.sun.xml.ws.developer.StreamingAttachment; impo ...

  2. WIN7笔记本显示连接不可用

    如图所示,找不到任何无线网络 解决方法: 不小心把无线关掉而已,笔记本键盘上F5~F12找看看有没有无线标志,有的话要先按下 Fn键不放,再按下那个有无线标志的Fn键.

  3. bzoj2244[SDOI2011]拦截导弹

    http://www.lydsy.com/JudgeOnline/problem.php?id=2244 第$i$个导弹看成一个三元组$(i,h_i,v_i)$ 其实就是最长上升子序列的问题. 我们分 ...

  4. 实现QQslidingMenu侧滑效果学习笔记

    声明:只是自己的学习笔记,所以,只作为博友的参考,不喜勿喷 实现思路: 自定义继承HorizontalScrollView的控件 项目github地址: https://github.com/ysno ...

  5. SQL-Delete Duplicate Emails

    Write a SQL query to delete all duplicate email entries in a table named Person, keeping only unique ...

  6. linux0.12 链接过程

    终于编译OK了..可链接就是一大堆错误 问题1: boot/head.o: In function `startup_32': (.text+0x10): undefined reference to ...

  7. (转)在Android的webview中定制js的alert,confirm和prompt对话框的方法

    1.首先继承android.webkit.WebChromeClient实现MyWebChromeClient. 2.在MyWebChromeClient.java中覆盖onJsAlert,onJsC ...

  8. nexus4/5/6/7/9/10设备谷歌安卓5.1.1系统底包下载

    https://developers.google.com/android/nexus/images http://www.inexus.co/thread-18488-1-1.html

  9. gcc和g++编译c或者c++文件碰到的问题

    gcc和g++都是GNU(组织)的一个编译器.        误区一:gcc只能编译c代码,g++只能编译c++代码      两者都可以,但是请注意:      1.后缀为.c的,gcc把它当作是C ...

  10. Android文字的复制和粘贴

    Android中提供了简单的额复制粘贴功能.代码很简单 复制文字的代码: ClipboardManager cbm= (ClipboardManager) MainActivity.this .get ...