hibernate映射文件怎么写

hibernate查询怎么写

1. hibernate查询怎么能写得简洁

把重复的提取出来,封装成方法就行了。

像这样的一个简单的工具类:

public final class HibernateUtil {

private static SessionFactory sessionFactory;

private HibernateUtil() {

}

static {

try {

sessionFactory = new Configuration().configure().buildSessionFactory();

} catch (HibernateException e) {

e.printStackTrace();

System.exit(-1);

}

}

public static SessionFactory getSessionFactory() {

return sessionFactory;

}

public static Session getSession() {

return sessionFactory.openSession();

}

public static void closeSession(Session session) {

if (session != null)

session.close();

}

public static void saveEntity(Object entity) {

Session session = null;

try {

session = getSession();

session.beginTransaction();

session.save(entity);

session.getTransaction().commit();

} catch (HibernateException e) {

if (session.getTransaction() != null)

session.getTransaction().rollback();

throw e;

} finally {

closeSession(session);

}

}

}

以后,DAO方法的编码,就比原来简洁些了:

import static my.dao.impl.HibernateUtil.*;//为了便于使用,对HibernateUtil中所有的静态方法按需导入

public List<Goods> findAll() {

List<Goods> result = null;

Session session = null;

try {

session = getSession();

result = session.createCriteria(TGoods.class).list();

} catch(RuntimeException e) {

throw e;

} finally {

closeSession(s);

}

return result;

}

但这样的程度不够,并且并非只考虑开发效率和代码的可读性。在实际工作中更好的方法之一是用Spring框架的DAO支持。

2. hibernate查询怎么能写得简洁

把重复的提取出来,封装成方法就行了。

像这样的一个简单的工具类: public final class HibernateUtil { private static SessionFactory sessionFactory; private HibernateUtil() {}static {try {sessionFactory = new Configuration().configure().buildSessionFactory(); } catch (HibernateException e) { e.printStackTrace(); System.exit(-1);}} public static SessionFactory getSessionFactory() { return sessionFactory;} public static Session getSession() { return sessionFactory.openSession();} public static void closeSession(Session session) { if (session != null) session.close();}public static void saveEntity(Object entity) { Session session = null;try {session = getSession(); session.beginTransaction(); session.save(entity); session.getTransaction().commit(); } catch (HibernateException e) { if (session.getTransaction() != null) session.getTransaction().rollback();throw e;} finally { closeSession(session);}}}以后,DAO方法的编码,就比原来简洁些了: import static my.dao.impl.HibernateUtil.*;//为了便于使用,对HibernateUtil中所有的静态方法按需导入 public List findAll() { List result = null; Session session = null;try {session = getSession(); result = session.createCriteria(TGoods.class).list(); closeSession(s);}return result;}但这样的程度不够,并且并非只考虑开发效率和代码的可读性。

3. hibernate中的查询方式有哪些

hibernate的查询方式主要有以下几种,你可以看看,也可以去官方下载文档来看看,不过是英文版本。

希望对你有帮助,谢谢 hibernate查询方式 ♦ 小结Hibernate。 ♦ Hibernate对多。

♦ hibernate查询。 ♦ Hibernate之查。

♦ Hibernate 查。 更多相关推荐。

在HQL中关键字不区分大小写,但是属性和类名区分大小写,下面介绍各种类型的Hibernate的HQL查询。1、Hibernate HQL查询:简单属性查询* 单一属性查询,返回结果集属性列表,元素类型和实体类中相应的属性类型一致* 多个属性查询,返回的集合元素是对象数组,数组元素的类型和对应的属性在实体类中的类型一致 数组的长度取决与select中属性的个数* 如果认为返回数组不够对象化,可以采用HQL动态实例化Student对象2、Hibernate HQL查询:实体对象查询* N + 1问题,在默认情况下,使用query.iterate查询,有可以能出现N+1问题,所谓的N+1是在查询的时候发出了N+1条sql语句,1: 首先发出一条查询对象id列表的sql,N: 根据id列表到缓存中查询,如果缓存中不存在与之匹配的数据,那么会根据id发出相应的sql语句* list和iterate的区别?* list每次都会发出sql语句,list会向缓存中放入数据,而不利用缓存中的数据* iterate:在默认情况下iterate利用缓存数据,但如果缓存中不存在数据有可以能出现N+1问题3、Hibernate HQL查询:条件查询* 可以采用拼字符串的方式传递参数 Java代码:List students = session.createQuery("select s.id, s.name from Student s where s.name like '%1%'").list(); * 可以采用 ?来传递参数(索引从0开始) Java代码:List students = session.createQuery("select s.id, s.name from Student s where s.name like ?").setParameter(0, "%1%").list(); //可以使用?方式传递参数 //参数的索引从0开始 //传递的参数值,不用单引号引起来 //注意方法链编程 * 可以采用 :参数名 来传递参数 Java代码:List students = session.createQuery ("select s.id, s.name from Student s where s.name like :myname").setParameter("myname", "%1%").list(); * 如果传递多个参数,可以采用setParamterList方法 Java代码:List students = session.createQuery("select s.id, s.name from Student s where s.id in(:myids)").setParameterList("myids", new Object[]{1, 2, 3, 4, 5}).list(); * 在HQL中可以使用数据库的函数,如:date_format Java代码:List students = session.createQuery("select s.id, s.name from Student s where date_format(s.createTime, '%Y-%m')=?").setParameter(0, "2008-02").list(); SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); //查询2008-01-10到2008-02-15创建的学生 List students = session.createQuery("select s.id, s.name from Student s where s.createTime between ? and ?") ..setParameter(0, sdf.parse("2008-01-10 00:00:00")) .setParameter(1, sdf.parse("2008-02-15 23:59:59")) .list(); 4、Hibernate HQL查询:直接使用sql进行查询 Java代码:List students = session.createSQLQuery("select * from t_student").list(); 不会返回对象,而是所有属性! 5、Hibernate HQL查询:分页查询* setFirstResult(),从0开始* setMaxResults,每页显示多少条数据 Java代码:List students = session.createQuery("from Student") .setFirstResult(1) .setMaxResults(2) .list(); 6、Hibernate HQL查询:对象导航查询,在HQL中采用 . 进行导航7、Hibernate HQL查询:连接查询* 内连 Sql代码:SELECT s.name, c.name FROM Student s (inner) join s.classes c * 外连接(左连接/右连接) Sql代码:SELECT s.name, c.name FROM Student s left join s.classes c 8、Hibernate HQL查询:统计查询 Java代码: List students =session.createQuery("select c.name, count(s) from Student s join s.classes c " +"group by c.name order by c.name").list(); for (Iterator iter=students.iterator(); iter.hasNext();) { Object[] obj = (Object[])iter.next(); System.out.println(obj[0] + ", " + obj[1]); } 9、DML风格的操作(尽量少用,因为和缓存不同步) Java代码:session.createQuery ("update Student s set s.name=? where s.id< ?") .setParameter(0, "李四") .setParameter(1, 5) .executeUpdate(); 应当尽量少用,因为和缓存不同步,也就是说,假如在执行上面的语句之前,已经把student封装成一个list曾经拿了出来,再执行上面的语句对 student中的表进行数据更新,然后再list Student表,则此时的list是从缓存中取的数据,而不是从表中找到的数据,也就是 说,list拿到的是update前的数据,所以造成了这种不同步,所以这种风格尽量少用。

从这个方面也可以看得出Hibernate并不适用于聚集性,统计,大量批量的更新,删除等操作。

4. hibernate一对一查询怎么写

bean对象的结构:User表:@Entity@Table(name="t_users")public class User {private String userId; private String userCaption; private String photo; private String phone; private String password; private String createTime; private Integer userStatus; private String lastLoginTime; private String parentId; private String tags; private String idCard; private String description; private Set roleId; private String userToken;123456789101112131415161718Role表:@Entity@Table(name="t_role")public class Role {private int roleId; private String roleName; private String rights; private String desctiption; private String tags; private Set user;1234567891011数据库: 查询方法:需要查出user中的角色总共有多少人 6为合伙人的角色List partnerRole = baseDao.findByHql("from Role where id = 6");Role p = partnerRole.get(0);Set partners = p.getUser();Integer partnerCount = partners.size();。

5. hibernate怎么用查询

1:hibernate数据查询方式:有HQL方式,QBC方式,原生SQL方式。HQL适合静态查询,QBC则适合较多的动态查询。

A:HQL方式,支持条件查询,连接查询,分页查询,分组查询,内置函数和自定义函数查询(SUN(),MIN(),MAX()),子查询,动态绑定参数查。

HQL语句定义如下:

String hql="from book";

Query query=session.createQuery(hql);

B:QBC方式,也就是QBC检索方式。QBC通过Session类创建Criteria实例,通过不同方法进行检索,实际上Criteria是用来装载查询条件的容器。QBC有很多条件函数,如:Resstictions.eq(),Resstictions.gt(),Resstictions.ge(),

Resstictions.le(),Resstictions.and(),Resstictions.or()等。

Criteria容器使用方法如下:

Criteria criteria=session.createCriteria(book.class);

criteria.add(Restrications.It("id",new Integer(4)));

List list=criteria.list();

C:原生SQL方式。不管是HQL还是QBC最终都要通过Hibernate来解析,把他们转换成SQL语句进行对数据库的操作。因为我们知道SQL可以在多平台之间使用。

使用原生SQL方式如下:

String sql="select {b.*} from book b"

SQLQuery squery=session.createSQLQuery(sql);

squery.addEntity("b",book.class);

List list=squery.list();

2:hibernate的关联查询

A:一对一关联:

B:一对多,多对一关联

C:多对多关联

最后,要学hibernate,平时要多动手,慢慢积累经验,成就感就会也大,这样才能学而不厌。祝你学习进步。

6. Hibernate的查询是怎么实现的

简单地说,Hibernate在查询出一行数据之后,内部实现还是将数据读出到ResultSet里,然后分析session.get(Class, Object)函数的Class参数,通过类反射可以知道该Class包含哪些对象并且newInstance一个该类的对象,然后从ResultSet读出属性填充到该对象。用户只需要对这个对象进行简单的类型转换就可以使用了。

代码也有,是之前写一个持久化类库的时候写的。

static final ActiveRecord setupObject (Object object, ResultSet resultSet) throws java.sql.SQLException, ObjectAnalysisException

{

Map<Field, Accesstor> fields = ActiveRecord.analizeObjectFields(object);

try

{

for(Field field : fields.keySet())

{

Object value = resultSet.getObject(field.getName());

if(value != null)

fields.get(field).getSetter().invoke(object, value);

}

}

catch(SQLException err)

{

throw err;

}

catch(Exception err)

{

if(err instanceof IllegalAccessException || err instanceof IllegalArgumentException)

throw new ObjectAnalysisException(err.toString(), err);

else if(err instanceof InvocationTargetException)

throw new ObjectAnalysisException(err.toString(), err);

}

object.setId(resultSet.getLong("id"));

return object;

}

这段代码你无法编译因为还依赖其他的一些类,但是看看这个流程就大致能知道Hibernate如何智能地产生一个对象了。

转载请注明出处育才学习网 » hibernate映射文件怎么写

知识

罗梅芬用日文怎么写(罗钰潇日语怎么写)

阅读(21424)

本文主要为您介绍罗梅芬用日文怎么写,内容包括伊蕾娜日语怎么写,王雪菲用日文怎么说,张佳怡在日语中怎么写啊怎么读啊。罗 ら ラ ra钰 ぎょく ギョク gyoku潇 しょう シヨウ shou第一列:日语汉字,写法同汉字,都要用繁体,这三个都挺难写的,看

知识

邓先生的英文怎么写(1~40的英文怎么说)

阅读(10438)

本文主要为您介绍邓先生的英文怎么写,内容包括“邓先生”用英语怎么写,1~40的英文怎么说,漂亮英文beautiful缩写怎么写。1 one 2 two 3 three 4 four 5 five 6 six 7 seven 8 eight 8 nine 10 te

知识

一个人布满皱纹怎么写(描写人物皱纹的句子)

阅读(9513)

本文主要为您介绍一个人布满皱纹怎么写,内容包括描写人物皱纹的句子,描写人物皱纹的句子,皱纹怎么描写。、老人脸上布满了皱纹,那一条条曲折不均的像是墙上斑驳的印迹,爬满了面容,留下了岁月的痕迹。2、外祖父是一位年过六旬的白发老人。在他

知识

登录接口怎么写(php登录的接口怎么写)

阅读(7758)

本文主要为您介绍登录接口怎么写,内容包括php登录的接口怎么写,网页登陆接口怎么做,网站登录接口程序怎么做。PHP 接口 接口 使用接口(interface),你可以指定某个类必须实现哪些方法,但不需要定义这些方法的具体内容。我们可以通过int

知识

档案奖惩情况怎么写(奖惩情况怎么写)

阅读(9599)

本文主要为您介绍档案奖惩情况怎么写,内容包括奖惩情况怎么写,个人简历及奖惩情况怎么填写,个人简历里面奖惩情况怎么写。在简历里的“奖励”部分,列出与你所获得的并与你的求职目标相关的荣誉、奖励和奖金。你既可以按时间顺序排列,也可以按

知识

头孢克肟拼音怎么写(头孢克肟的肟念什么)

阅读(7999)

本文主要为您介绍头孢克肟拼音怎么写,内容包括头孢克肟片全名拼音,头孢克肟片全名拼音,头孢克肟的肟念什么。肟[wò] :是含有羰基的醛、酮类化合物与羟胺作用而生成的有机化合物,可以参与许多有机化学反应,例如经典的Beckmann重排就是肟为底

知识

一库搜用日语怎么写(日语一库是什么意思)

阅读(7987)

本文主要为您介绍一库搜用日语怎么写,内容包括日语大神来,看动漫里的主人公说一句:恰,一库搜这是什么意思,一库一库;一搜库这两个日语是什么意思怎么写,看片都有“一库”(日语)是什么意。一库的意思就是“出发,出去”的意思。日语「行く」的音译

知识

外租无人机广告怎么写(植保无人机广告语)

阅读(6997)

本文主要为您介绍外租无人机广告怎么写,内容包括求一个无人机创意广告词谢谢巨友们了,求一关于无人机的广告标语,求一关于无人机的广告标语我们公司是做无人机的,新成立的公司,求。DJI大疆创新研发的的MG-1农业植保机专为农村作业环境设计,

知识

河南话que怎么写(河南话的nenna怎么写)

阅读(6530)

本文主要为您介绍河南话que怎么写,内容包括que怎么写,河南话的nenna怎么写,que怎么写。尿一壶(niào yī hú)关系密切,观点一致。例:“他俩今天尿一壶啦。”●尿(niào)⑴、从尿道排泄的液体。⑵、排泄小便。⑶、不放

知识

国学经文的论文怎么写(国学征文该怎么写)

阅读(7112)

本文主要为您介绍国学经文的论文怎么写,内容包括国学征文该怎么写,弟子规的400论文,关于国学经典的征文怎么写。“子曰:“温故而知新,可以为师”……小时,总是觉得国学就是没用的,古人写的话,我们还需要背,每次老师教给我们时,我总是会让思想开一

知识

化学实验总结怎么写(化学实验报告小结怎么写)

阅读(5394)

本文主要为您介绍化学实验总结怎么写,内容包括化学实验总结怎么写,化学实验报告小结怎么写,化学实验小结怎么写。化学实验报告的书写: 一般情况下化学实验报告是根据实验步骤和顺序从七方面展开来写的: 1.实验目的:即本次实验所要达到的目标或

知识

蝴蝶豌豆拼音怎么写(豌豆的拼音是什么)

阅读(5823)

本文主要为您介绍蝴蝶豌豆拼音怎么写,内容包括蝴蝶怎么拼音的,豌豆的拼音是什么,蝴蝶的拼音是什么。豌豆的拼音是[wān dòu]。豌豆是豆科一年生攀援草本,高0.5-2米。全株绿色,光滑无毛,被粉霜。叶具小叶4-6片,托叶心形,下缘具

知识

海绵宝宝用英文怎么说(海绵宝宝用英文怎么说)

阅读(6509)

本文主要为您介绍海绵宝宝用英文怎么说,内容包括海绵宝宝用英语怎么说,海绵宝宝用英文怎么说,海绵宝宝英文名是什么。1. SPONGEBOB SQUAREPANTS 近期很夯的一步卡通影片《海绵宝宝》(SpongeBob SquarePants)是一系

知识

茶盏怎么用(茶盏在茶道中干嘛用)

阅读(5421)

本文主要为您介绍茶盏怎么用,内容包括茶盏怎么用我要写一篇200字左右的茶盏的使用说明,求指教,茶盏在茶道中干嘛用,问一下斗笠盏如何使用现在是不是很少有人使用它,它的意义。苏东坡的名句"从来佳茗似佳人",典型地代表了唐宋及以后的文人墨客,

知识

thinkpad小红点怎么用(怎么学习使用thinkpad小红点)

阅读(7581)

本文主要为您介绍thinkpad小红点怎么用,内容包括怎么学习使用thinkpad小红点,thinkpad小红点怎么用,求教:THINKPAD的小红点使用方法。Thinkpad 小红点最高效的使用方法为:左手拇指按左键,无操作时在左键待命2、右手拇指按右键,同时兼按空格键及