Hibernate查询数据的几种方式以及HQL用法及参数的几种使用方法

本文介绍了四种Hibernate查询方式:使用query接口与HQL语句、criteria接口、SQLQuery接口及get/load方法查询数据,并展示了HQL参数绑定及批量更新/删除操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

[size=medium][color=darkred]Hibernate查询数据的几种方式[/color][/size]
[color=green]
/**
* 第一种查询:利用query接口与HQL语句
* 1.如果查询所有字段,则list中的元素为POJO对象
* 2.如果查询若干字段,则list中的元素为对象数组
* 3.如果想返回若干字段的对象,则需要通过 new TUser(username,email)方式
*/[/color]

public void query(){
Session session = null;
Query query = null;
String hql = null;
try {
session = HibernateSessionFactory.getSession();
hql="From TUser user where user.suser='admin'";
query = session.createQuery(hql);
List list = query.list();
for (Iterator iter = list.iterator(); iter.hasNext();) {
TUser user = (TUser) iter.next();
System.out.println("----Query---");
System.out.println("-Suser-="+user.getSuser());
System.out.println("-Name--="+user.getName());
System.out.println("-Email-="+user.getEmail());
}
} catch (Exception e) {
e.printStackTrace();
}finally{
HibernateSessionFactory.closeSession();
}
}

[color=green]
/**
* 第二种查询:利用criteria接口
*/[/color]

public void criteria(){
Session session = null;
Criteria criteria = null;
try {
session = HibernateSessionFactory.getSession();
criteria = session.createCriteria(TUser.class);
criteria.add(Restrictions.isNotNull("suser"));
criteria.add(Restrictions.ilike("name", "%T%"));
criteria.addOrder(Order.desc("nation"));
List list = criteria.list();
for (Iterator iter = list.iterator(); iter.hasNext();) {
TUser user = (TUser) iter.next();
System.out.println("----Criteria---");
System.out.println("-Suser-="+user.getSuser());
System.out.println("-Name--="+user.getName());
System.out.println("-Email-="+user.getEmail());
System.out.println("-Nation="+user.getNation());
}
} catch (Exception e) {
e.printStackTrace();
}finally{
HibernateSessionFactory.closeSession();
}
}

[color=green]
/**
* 第三种查询:利用SQLQuery接口,即原生SQL
* 1.如果查询所有字段,要加入标量设置query.addEntity(TUser.class);
* 2.如果查询若干字段,则集合中数据为对象数组
*/[/color]

public void nativeSql() {
Session session =null;
Query query = null;
String sql = null;
try {
session = HibernateSessionFactory.getSession();
sql = "select suser,name,email,nation from t_user";
query = session.createQuery(sql);
List list = query.list();
for (Iterator iter = list.iterator(); iter.hasNext();) {
Object[] obj = (Object[]) iter.next();
System.out.println("-Suser-="+obj[0]);
System.out.println("-Name--="+obj[1]);
System.out.println("-Email-="+obj[2]);
System.out.println("-Nation="+obj[3]);
}
} catch (Exception e) {
e.printStackTrace();
}finally{
HibernateSessionFactory.closeSession();
}
}

[color=green]
/**
* 第四种查询:查询单个对象,注意get和load方法的区别
*/[/color]

public void getOrLoad(){
Session session = null;
try {
session = HibernateSessionFactory.getSession();
TUser user = (TUser)session.load(TUser.class, "test1");
System.out.println("-Suser-="+user.getSuser());
System.out.println("-Name--="+user.getName());
System.out.println("-Email-="+user.getEmail());
System.out.println("-Nation="+user.getNation());
} catch (Exception e) {
e.printStackTrace();
}finally{
HibernateSessionFactory.closeSession();
}
}

[size=medium][color=darkred]HQL用法及参数的几种使用方法[/color][/size]
[color=green]
/**
*按参数位置绑定
*/
[/color]

public void batchUpdate() {
Session session = null;
Transaction transaction = null;
Query query = null;
String hql ="update TUser set name='阿德' where suser=:user";
try {
session = HibernateSessionFactory.getSession();
transaction =session.beginTransaction();
query = session.createQuery(hql);
query.setString("user", "test9");
int i = query.executeUpdate();
transaction.commit();
System.out.println("--update--"+i);
} catch (Exception e) {
e.printStackTrace();
transaction.rollback();
}finally{
HibernateSessionFactory.closeSession();
}
}

[color=green]
/**
*按参数位置绑定
*/
[/color]

public void batchDelete() {
Session session = null;
Transaction transaction = null;
Query query = null;
String hql = "delete from t_user suser=:user";
try {
session = HibernateSessionFactory.getSession();
transaction = session.beginTransaction();
query = session.createQuery(hql);
query.setString("user", "test11");
int i = query.executeUpdate();
transaction.commit();
System.out.println("--delete--"+i);
} catch (Exception e) {
e.printStackTrace();
transaction.rollback();
}finally{
HibernateSessionFactory.closeSession();
}
}

[color=green]
/*
*使用setProperties方法
*/
[/color]

public void queryUsers() {
Session session = null;
Transaction transaction = null;
Query query = null;
String hql =null;
try {
session = HibernateSessionFactory.getSession();
hql = "from TUser where suser=:user";
transaction = session.beginTransaction();
query = session.createQuery(hql);
TUser user = new TUser();
user.setSuser("test1");
query.setProperties(user);
List list = query.list();
for (Iterator iter = list.iterator(); iter.hasNext();) {
Object[] obj = (Object[]) iter.next();
System.out.println("-Suser-="+obj[0]);
System.out.println("-Name--="+obj[1]);
System.out.println("-Email-="+obj[2]);
System.out.println("-Nation="+obj[3]);
}
} catch (Exception e) {
e.printStackTrace();
transaction.rollback();
}finally{
HibernateSessionFactory.closeSession();
}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值