自己一星期总结:20:02 2008-11-2晚上
Hibernate
1.简介
数据库数据都是以RDBS存在数据库中的即关系型数据库,Hibernate以对象形式
与数据库数据动态绑定,关于对象地方法以前是以前用的JDO和EJB,但EJB效率低
(注EJB3.0吸取了Hibernate中的东东)
2.Hibernate项目开发
需要Jar包,创建数据库连接文件hibernate.cjg.xml
“Plain Ordinary Java Object”即POJO,实体Entity继承java.io.Serializable(VO)
映射文件以 .hbm.xml结尾
HibernateSessionFactory类负责读取hibernate.cjg.xml信息并与数据库连接等
注在HibernateSessionFactory中
SessionFactory负责创建Session 实例(这儿的Sessin相当于
Connection,不能与仓库Session混淆)
***注意所有文件的配置,不能出错否则无法与数据库连接
3.Hibernate对数据库的操作
连接数据库 Session session = HibernateSessionFactory.getSession();
(1) Hibernate支持Criteria Query、HQL、SQL
Hibernate会根据Criteria Query、HQL自动生成SQL语句,但如果操作很复杂时自动
生成的SQL效率非常低下,复杂时应自己设计SQL语句
(2) session.save(user);添加
session.update(user);修改
session.delete(user);删除
HQL中的基本语句
hql="from User us where us.naem = :name"
复杂的
如
查询宠物名为qq的主人 hql="from Owner as ow inner join ow.Pet as p where p.name=:name";
查询发这条留言的学生 hql="from Student s left join s.information
info where info.content=:content";
(3)分页操作
一般查询分页
Query q = session.createQuery(hql);
q.setMaxResults(count);//每次查出的条数
q.setFirstResult(start);//从哪儿条数据开始
Integer count = ((Number)q.uniqueResult()).intValue();//获取总条数
模糊查询分页
Criteria criteria = session.createCriteria(Pet.class);
criteria.setMaxResults(cont);//每次查出的条数
criteria.setFirstResult(start);//从哪儿条数据开始
Integer count = ((Number)criteria.uniqueResult()).intValue();//获取总条数
(4)模糊查询Criteria
Criteria criteria = session.createCriteria(Pet.class);
//条件相当于like '%%'
if(name1!=null)criteria.add(Expression.like("name", name1));
if(tezheng!=null)criteria.add(Expression.like("tezheng",tezheng));
**** 用Criteria时可以进行排序操作criteria.addOrder(Order.asc("name"));//名字升序
criteria.addOrder(Order.desc("groupId"));//Id降序
(5)在 .hbm.xml中配置查询语句(SQL && HQL)
在.hbm.xml中
<query flush-mode="always" name="语句名">语句</query>
在JavaBean
Query q = session.createQuery(语句名);
(6)ORMapping(Object Relationgship mapping)实体映射
数据表的关系(很重要):
1.(1:1)
<one-to-one>
2.(n:1) && <1:n>例 主人和宠物
宠物实体 private Onwer onwer;
在Pet.hbm.xml中
<many-to-one name="onwer" class="com.entity.Onwer" lazy="false">
<column name="onwerId" />
</many-to-one>
注:lazy="true"or"false"是负责数据是否全部装载
<one-to-many>
3.(n:n);例 学生和老师
</many-to-many>效率及其低下我们一般用两个(n:1) && <1:n>解决
多对多时需要建三个表