Hibernate 总结(转)

JMX:Java Management Extensions.
JCA: J2EE Contector Architecture
JNDI: Java Namind and Directory Interface.
Hibernate并不是作为数据库连接层替代JDBC,而是位于JDBC之上的一层。
无论在什么环境中集成Hibernate,都需要定义应用的配置细节,然后用一个Configuration对象表示这些信息,才能够Configuration对象创建一个SessionFactory对象,然后从SessionFactory对象实例化Session对象,应用程序通过Session对象访问Hibernate的数据库表示。

一、Hibernate总括:

 * 1、数据库本身不能被创建,只能创建数据库的表,所以,
 *    在利用hibernate创建数据库的表时应当首先手动创建
 *    数据库本身。
 * 2、hibernate的默认配置文件名是hibernate.cfg.xml,如果创建的
 *    配置文件的文件名与此默认不相同则应该调用带文件名参数的
 *    configure(configfilename)方法,即:
 *    Configuration cfg=new Configuration().configure("configfilename")
 * 3、Configuration是hibernate的入口,而Configuration得实例化必须首先加载
 *    配置文件,该配置文件确定了数据库的配置信息同时引入了生成的数据库表的
 *    字段映射文件,配置文件的后缀名是:cfg.xml,而字段映射文件的后缀名则是
 *    hbm.xml
 * 4、hbm映射文件放在与类字节码文件同一目录下不是必须的,但必须保证cfg配置文件
 *    中mapping元素节点的resource属性所指向的文件全名与hbm映射文件的实际地址相同
 *    否则将抛出异常,但hbm映射文件的前缀名不一定与该文件中class节点元素的name所
 *    指向的类名保持一致,只是为了考虑便于类与数据库表的对应以免混淆才使文件名前缀
 *    与该文件中class节点元素的name属性所指向的类名相同,这样做了之后,通过文件名便
 *    知道该映射文件是属于哪一个类对数据库表的映射。
 * 5、hibernate的两个配置文件中只有cfg配置文件的位置是固定在class目录之下,而映射文件
 *    的路径并不固定,这一点与struts的配置文件有区别,struts的配置文件的位置基本上都
 *    是固定的,这是因为在struts.xml文件中没有任何路径信息对其它配置文件的指向进行说明
 *    而hibernate中的cfg配置文件中有resource属性对其它配置文件的路径进行说明。
 * 6、如果数据中已经有一个表与当前所创建的表完全相同也不会发生异常,此时创建的新表将替换
 *    存在的旧表,即覆盖旧表。
 * 7、映射规则:
 *    A、hbm映射文件中定义的字段名称必须与映射类的属性名称保持一致,否则将抛出异常
 *    B、hbm映射文件中必须要有主键,该键不能缺少否则将抛出异常
 *    C、hbm映射文件中非主键可以不给出定义,于此,数据库表中将不生成该字段
 *    D、有A、C两点可以看出数据库表中的字段名称必须与映射的类中属性名称相同
 *       但属性字段的个数则不一定对应。
 二、Hibernate插入数据:
 *
 * 1、不能向数据库中插入存在约束的数据,否则将抛出异常,比如:
 *    不能有两次插入相同的id,因为id是数据库表中的主键,其值
 *    是唯一的,两次插入相同的id值将导致数据库表中的id键值重
 *    复,从而抛出异常。
 * 2、若没有设置主键id的值,则对象的属性成员将接受JVM分配的默认值,如
 *    字串为null,数值类型为0;主键为null时将不能向表中插入数据,
 *    但不会抛出异常。
 三、Hibernate删除数据:
 * 1、对于删除数据库记录的情况只需要指定主键即可(注意:这种
 *    情况只能指定主键,不能指定其它的非主键值作为删除条件)
 * 2、可以采用HQL(注意这里只能采用HQL语句,不支持SQL语句)语句
 *    来进行条件删除,此时必须利用Session调用createQuery()来
 *    创建一个Query的预编译对象,该对象调用setObject()方法为
 *    占位符赋值,最后由该对象调用executeUpdate()来准备操作数据库
 四、Hibernate更新数据:
   1、修改时必须用set()方法指明主键,否则将抛出异常
 * 2、其它字段原则上还是要通过set()方法来重新指定,否则hibernate
 *    将采用类中成员的默认值(引用类型为null,数值类型为0)
 * 3、如果类中的字段较多时可以采用反射来完成赋值。
 * 4、在修改时通过set方法所给定的条件数据必须符合表中字段的值,
 *    如果表中没有任何字段或是条件不合符表中字段都将抛出异常。
 * 5、事务在完成之后必须采用commit()方法提交事务,否则将不会对
 *    数据库表做任何修改,只有在利用commit方法提交事务时,其增删改查等
 *    动作才开始正式执行。
 * 6、一次会话完成之后通常要关闭数据库连接流,注意:关闭此流并不等于不用
 *    commit提交事务就能完成数据库操作,要完成数据库的操作必须用commit提交事务。
 五、Hibernate查询数据:
    1、在Hibernate中执行SQL语句的占位赋值时下标从0开始的
    2、查询时把数据库中的数据提取出来,没有事务的概念
       而增删改则牵涉对数据库的修改所以有事务的概念
    3、查询中只能通过HQL或SQL语句来进行查询,会话对象
       Session中没有专门的查询方法。
    4、最后不推荐使用SQL语句,SQL的语句执行结果经常发生类型与
       原定义类型不兼容的情况。
    5、这里提出的建议是最好将会话流关闭,尽管仍然能够查询出数据
 六、Hibernate创建表:
     Configuration cfg=new Configuration().configure("hibernate.cfg.xml全名");

   SchemaExport sExport=new SchemaExport(cfg);
 
    sExport.create(true,true);
   

原文地址:https://www.cnblogs.com/happinessqi/p/3495963.html