Hibernate查询方法总结
1. HQL查询
后面是表名
Person; from
后面是类。可以对类起别名,有两种方法。hql:
from Person p
hql:from
Person
as p
Session s = sessionFactory.openSession();
String strQuery = "from Person where name=:name";
Query query = s.createQuery(strQuery);
query.setString("name", "张三");
List<Person> lst = query.list();
for(Person p : lst){
<span style="white-space:pre"> </span>System.out.println(p);
}
适用情况:常用方法,比较传统,类似jdbc。缺点:新的查询语言,适用面有限,仅适用于Hibernate框架。
2. Criteral查询
Session s = sessionFactory.openSession();
Criteria criteria = s.createCriteria(Person.class);
criteria.add(Restrictions.eq("name", "张三"));
List<Person> lst = criteria.list();
for(Person p : lst){
<span style="white-space:pre"> </span>System.out.println(p);
}
适用情况:面向对象操作,革新了以前的数据库操作方式,易读。缺点:适用面较HQL有限。
3. DetachedCriteria查询
private List<Person> dc(DetachedCriteria dc){
<span style="white-space:pre"> </span>Session s = sessionFactory.openSession();
Criteria criteria = dc.getExecutableCriteria(s);
return criteria.list();
}
DetachedCriteria dc = DetachedCriteria.forClass(Person.class);
dc.add(Restrictions.eq("name", "张三"));
List<Person> lst = dc(dc);
for(Person p : lst){
<span style="white-space:pre"> </span>System.out.println(p);
}
适用情况:面向对象操作,分离业务与底层,不需要字段属性摄入到Dao实现层。
缺点:适用面较HQL有限。
4. Example 查询
Person p = new Person();
p.setName("张三");
//p.setName("张%");
Session s = sessionFactory.openSession();
Criteria c = s.createCriteria(Person.class);
Example example = Example.create(p);
example.excludeProperty("age");//排除年龄属性
example.excludeProperty("birthDay");
example.excludeProperty("id");
//example.enableLike();//启用模糊查询
List<Person> list = c.add(example).list();
for(Person p1 : list){
System.out.println(p1);
}
适用情况:面向对象操作。
缺点:适用面较HQL有限,不推荐。
5.
sql查询
Session s = sessionFactory.openSession();
String strQuery = "select * from person where pname=:name";//条件应为表的属性
Query query = s.createSQLQuery(strQuery).addEntity(Person.class);
//java.lang.ClassCastException: [Ljava.lang.Object; cannot be cast to hibernate.entity.Person
query.setString("name", "张三");
List<Person> list = query.list();
for(Person p1 : list){
System.out.println(p1);
}
适用情况:不熟悉HQL的朋友,又不打算转数据库平台的朋友,万能方法
缺点:破坏跨平台,不易维护,不面向对象,查询条件的属性应和平常的SQL一样,采用表的属性。
6. 命名查询
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
'-//Hibernate/Hibernate Mapping DTD 3.0//EN'
'http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd'>
<hibernate-mapping>
<class name="hibernate.entity.Person" table="person">
<id name="id" column="pid"></id>
<property name="name" column="pname"></property>
<property name="birthDay" type="date" ></property>
<property name="age"></property>
</class>
<query name="getPersonByName">
<![CDATA[from Person where name=:name]]>
</query>
</hibernate-mapping>
Session s = sessionFactory.openSession();
Query HQLquery = s.getNamedQuery("getPersonByName");
HQLquery.setString("name", "张三");
List<Person> list = HQLquery.list();
for(Person p1 : list){
System.out.println(p1);
}
适用情况:万能方法,有点像ibatis轻量级框架的操作,方便维护。
缺点:不面向对象。基于hql和sql,有一定缺陷。
上述六种查询方法,HQL查询,SQL查询,命名查询比较好用。
Hibernate查询方法总结的更多相关文章
- Hibernate 查询方法
1.简单查询: public User select(User user) { User newUser; try { newUser = (User) session.get(User.class, ...
- J2EE进阶(十七)Hibernate中常用的HQL查询方法(getHibernateTemplate())
J2EE进阶(十七)Hibernate中常用的HQL查询方法(getHibernateTemplate()) 当我们使用Hibernate进行数据的CRUD操作时,利用模版进行操作不失为一种方法. ...
- hibernate查询竟然有6种方法
hibernate查询的6种方法 1.HQL查询 2.对象化查询Criteria方法 3.动态查询DetachedCriteria 4.例子查询 5.sql查询 6.命名查询 1.HQL查询 stat ...
- Hibernate查询出现java.lang.IllegalArgumentException异常解决方法
Hibernate查询出现java.lang.IllegalArgumentException. 异常信息如下:java.lang.IllegalArgumentException at ...
- Hibernate查询对象的方法浅析
Hibernate 查询对象是根据对象的id查询的,只要你有id (id唯一),则无论你是否其他字段与传过来的对象一致,都会查到该id在数据库对应的对象.若是在关联查询中,所关联表的id为空,即所查表 ...
- Hibernate查询
HIbernate查询 使用get方法 使用get方法通过持久类名和ID号查找一个对象Stu instance = (Stu) getsession() .get("com.lovo.po. ...
- hibernate查询方式
hibernate查询方式:1.本地SQL查询 2.HQL查询 3.QBC查询 HQL查询:是面向对象的查询语言,是使用最广的一种查询方法 QBC查询:Query by Criteria是一套接口来实 ...
- 六种方式实现hibernate查询
最近在学习Hibernate的基本内容,刚好在项目中有用到,基本上都是用到哪就学哪. 今天看看六种方式实现hibernate查询......... 分别是HQL查询,对象化查询Criteria方法,动 ...
- 记录使用Hibernate查询bean中字段和数据库列类型不匹配问题
今天在工程中遇到Hibernate查询的时候,bean中的字段和数据库中的字段不符合(bean中有pageTime字段,但是数据库中没有此列)报错问题. 具体问题环境: 在auto_off表中,off ...
随机推荐
- Checbox的操作含已选、未选及判断代码
Checbox的操作包括已选.未选.判断等等,下面有个不错的示例,使用jquery完成,感兴趣的朋友可以参考下 $("#chk1").attr("checked" ...
- Ubuntu启动项设置——之update-rc.d 命令使用
http://blog.csdn.net/typ2004/article/details/38712887 apache2.nginx.redis这些服务安装之后,会随开机启动,当这些服务并不需要时, ...
- WPF界面特殊字符处理
界面XAML不支持< .>.&."等字符. 使用字符实体编码进行替代,以下是pro WPF 4.5的摘要表 Special Character ...
- 【技巧】DataGridView,ListView重新绑定时保持上次滚动位置
(1)DataGridView 今天在项目时遇到一个问题,将DataTable绑定到DataGridView,其中一列为CheckBox列,当我修改该列值时,触发CellValueChanged事件. ...
- copy,retain,assign,strong,weak的区别
引用地址:http://www.aichengxu.com/view/32930 一.assign,copy,retain 1.copy是内容复制,新建一个相同内容的不同指针,retain为指针复制, ...
- Windows命令行语法说明
摘自:http://lavasoft.blog.51cto.com/62575/1113234 Windows命令行语法说明 说来惭愧,用windows这么多年了,对其命令行语法看得似懂非懂, ...
- Linq语句与aspnetpager结合分页
public void DataBindList() { List<EnDeContent> listCon = null; in ...
- 多个div独立控制其显示/隐藏
今天要说一个神奇的html标签op,静态页下可以配合jquery分别控制每个层的显示/隐藏切换. 如果用动态中使用,用文章id做区分就可以了. <html> <head> &l ...
- 最浅显、易懂的Linux 硬链接与软链接的理解
正文: Linux上的文件可以这么理解:文件-->文件名.文件是一个Object,也就是磁盘上的二进制数据.一个文件可以有多个文件名,平时我们都是通过文件名访问文件Object. 这样,硬链接可 ...
- linux禁止root用户直接登录sshd并修改默认端口
linux最高权限用户root,默认可以直接登录sshd.为了提高服务器的安全度,需要对它进行禁止,使得攻击者无法通过暴力破解来获取root权限. 1,新建一个用户: #useradd xxx (xx ...