Hibernate基础(by cju)

   自己一星期总结: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>解决
        多对多时需要建三个表
 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值