1、 HQL是面向对象的查询语言,HQL总的对象名是区分大小写的,HQL中查询的是对象而不是元素,并且支持多态。其主要通过Query来操作—创建方式:
Query q=session.createQuery(hql);
2、 HQL查询语句(例)
a) from User user where user age=20;查询年龄为20的人
b) from User user where user age between 20 and 30; 查询年龄为20或30的人
c) “from User as user where user.name=:n“ where user.name=:n命名参数
3、例题:public static void query(String name){
Session s=null;
try{
s=HibernateUtil.getSession();
String queryString="from User as user where user.name=:n";//from +类---查询user表里的所有记录----查询字符串---hibernate的查询语言----HQL
//where user.name=:n命名参数
Query query=s.createQuery(queryString);
query.setString("n",name);
query.setFirstResult(3);
query.setMaxResults(2);
List<User> list=query.list();
for(User u:list){
System.out.println(u.getId()+":"+u.getName());
}
/*User user=(User) query.uniqueResult();//查询一行。结果集超过一行会拋异常
System.out.println(user.getId()+":"+user.getName()); */
}finally{
if(s!=null){
s.close();
}
}
}
3、 HQL与SQL的不同
a) sql面向数据库查询。hql面向对象查询
b) 查询语句’
i. hql:from后面跟 类名+类对象 where 后用对象的属性做条件。
ii. sql:from后面跟的是表名。where后用表中字段做条件
4、 注意:
a) HQL是面向对象的 而对象类的名称和属性都是大小写敏感的,所以HQL是大小写敏感的。
b) from子句
i. 单个参数查询:from User user where user.Name=?
ii. 多个参数查询;:Sreing hql=”from User as user where user.loginName=? and user.age=?”;
iii. 查询数量 “select count (*) from User”
iv. 查询记录分页。限制查询开始记录和最大查询条数
String hql=”from User user order by user.logInName”’;
int firstResult=50;int maxResults=50;
Query query=session.createQuery(hql);
query=query.setFirstResult(firstResult);
query =setMaxResults(maxResults);
c) 新增;构建新增对象调用session对象的save()方法
d) 更新:取得需要跟新的持久化对象后执行session的update()方法
e) 删除:取得某个对象后。调用session的delete()方法
f) eg:
public User findUserById(int id) {
//按ID查找
Session session=null;
try{
session =HibernateUtil.getSession();//调用
Class clazz=User.class;
User user=(User) session.get(clazz,id);
return user;
}finally{
if(session!=null){
session.close();
}
}
}
@Override
public void findUserByName(String name) {
//按名字查找
Session session=null;
try{
session =HibernateUtil.getSession();//调用
String queryString="from User as user where user.name=:n";
Query query=session.createQuery(queryString);
query.setString("n",name);
List<User> list=query.list();
for(User u:list){
System.out.println(u.getId()+":"+u.getName());
}
}finally{
if(session!=null){
session.close();
}
}
}
@Override
public void remove(User user) {
//s删除
Session session =null;
Transaction tx=null;
try{
session =HibernateUtil.getSession();
tx=session.beginTransaction();
session.delete(user);
tx.commit();
}catch(HibernateException ex){
if(tx!=null){
tx.rollback();
}
}finally{
if(session!=null){
session.close();
}
}
}
@Override
public void saveUser(User user) {
//新增
Session session=null;
Transaction tx=null;
try{
session =HibernateUtil.getSession();//调用
tx=session.beginTransaction();
session.save(user);
tx.commit();
}catch(HibernateException ex){
if(tx!=null){
tx.rollback();//回滚事物
}
}finally{
if(session!=null){
session.close();
}
}
}
@Override
public void updateUser(User user) {
// TODO Auto-generated method stub
//跟新
Session session = null;
Transaction tx=null;
try{
session =HibernateUtil.getSession();
tx=session.beginTransaction();
session.update(user);
tx.commit();
}catch(HibernateException ex){
if(tx!=null){
tx.rollback();//回滚事物
}
}finally{
if(session!=null){
session.close();
}
}
}