zoukankan      html  css  js  c++  java
  • hibernate 学习笔记1

    Hibernate session1

    1.连接池的最小连接数指的是连接池初始化之后,就存在的连接数,这些连接放在内存中,等待被使用。最大连接数限定了连接池中最大同时连接数量,如果超过了这个数量,则进入等待队列中,需要等其他连接退出之后,才能进行连接。

    2.自动建表功能有create-drop,create,update和validate四种:

    1)create-dtrop是:drop->create->drop;

    2) create是:drop->create

    3)update是:先比较表的结构,如果表的结构发生变化,则:drop-create,否则不进行ddl操作;

    4)validate是:验证java对象与数据库表的一致性,如果不一致,则报错。

    5)SessionFactory不仅是一个数据库连接池,而且还保存了相应的数据库配置信息以及ORM、预定义的SQL语句。同时,还维护了hibernate的二级缓存。SessionFactory是重量级的对象,一个数据库只需要一个SessionFactory且最好在应用启动的时候完成他的初始化,SessionFactory是线程安全的。

    3.Session是hibernate中使用最为频繁的API,可以再一次数据库操作中,就使用一个Session,使用完之后立即关闭,就像Servlet的一次请求相应一样,用完就释放。Session是线程不安全的,Session对象有一个一级缓存,显式执行flush之前,缓存是不会提交到数据库中的。Session的常用方法有以下几个,这些方法对应了数据库的增删改查:

    1)  save(obj) ----保存数据

    2)  get(Class,id) ----通过主键查询该条记录

    3)  delete(obj)  ---删除数据,注意,为了方便和准确,删除的数据一般都是先查询出来的数据。

    4)  update(obj)  ---更新数据,注意,为了方便和准确,更新的数据一般都是先查询出来的数据。

    5)  saveOrUpdate(obj)  ---保存或修改数据

    6)createQuery(String hql)   ---查询所有的数据

    4.HQL就是hibernate中类似于sql的查询语句,是面向对象的。完整的HQL语句形式如下: Select/update/delete…… from …… where …… group by …… having …… order by …… asc/desc 其中的update/delete为Hibernate3中所新添加的功能,可见HQL查询非常类似于标准SQL查询。由于HQL查询在整个Hibernate实体操作体系中的核心地位.

    5.Transaction就是数据库的事物,用于满足ACID,提供了两个方法来实现提交或回滚操作:

    1) commit()  ---提交事务。在无异常时,直接提交,

    2) rollback()  ---回滚事务。一般是用在catch到异常之后,事务回滚。

    Hibernate默认不开启自动提交,而是用户通过Transaction接口手动提交事务

    如果没有开启事务,那么每个session的操作都是一个独立事务,即每一条sql语句都是一个事务。

    6.自然主键指的是有实际意义的主键,不如身份证号码。自然主键可能会在以后变得不唯一,比如以后因为有人去去世有人新生,有一天身份证号码不唯一了,那么数据库就会失效了,所以一般使用代理主键。

    7.主键的生成策略:

    1)increment:适用于short,int,龙作为主键,不是使用数据库的自动增长机制,而是hibernate来维护的。

      * hibernate中提供的一种增长机制:

      **先查询 : select max(id)  from person

      **再进行插入 :取得的最大值+1最为新纪录的主键

      *缺点:不能再集群和并发中使用。所以不常用

    2)identity:适用于short,int,long作为主键,但是这个必须使用在有自动增长功能的数据库中(支持auto_increment),采用的是数据库底层的自动增长机制。

    3)sequence:适用于short,int,long作为主键,底层采用的是序列的增长方式,需要制定序列。

    4)UUID:适用于char,varchar类型作为主键,使用框架随机产生的32位字符串作为主键。适合多线程。

    5)native:本地策略,适用于short,int,long作为主键,根据底层数据库的不同,自动选择适用于该种数据库的主键生成策略。

       *如果底层使用的是Mysql数据库,则相当于identity;

       *如果底层使用的是不支持auto_increment的oracle数据库,则相当于sequence。

    6)assigned:自然主键,用户自己管理,而不是由hibernate管理。

    注意:native和identity不仅需要数据库支持auto_increment,还要字段已经开启了AUTO_INCREMENT。

    8.属性字段尽量使用包装类而不是基础类型,这样,当没有set相应的值得时候,值为Null而不是基本类型的默认值。这样做的好处就是可以对应数据库的null值,从而区分是一个具体的值还是缺失值。比如一个学生的成绩,如果他没有参加考试,则是Null,如果分值为0,则说明他考试了,但是考了0分。

    9.持久化的java部分是:java bean+ Classname.hbm.xml

    10. useUnicode=true&characterEncoding=UTF-8,&要用实体类&  这里的characterEncoding同时设置了character_set_client和character_set_results环境变量。

  • 相关阅读:
    进程调度算法
    操作系统文件管理
    25 个精美的手机网站模板
    WEB和APP谁是互联网未来
    网站设计趋势
    百度搜索引擎中的快照及快照更新机制
    JS实现信息的显示和隐藏
    虚拟主机单线、双线、多线的区别
    Types of Entity in Entity Framework:
    DBContext
  • 原文地址:https://www.cnblogs.com/JMLiu/p/10178418.html
Copyright © 2011-2022 走看看