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);

Hibernate 总结(转)的更多相关文章

  1. hibernate多对多关联映射

    关联是类(类的实例)之间的关系,表示有意义和值得关注的连接. 本系列将介绍Hibernate中主要的几种关联映射 Hibernate一对一主键单向关联Hibernate一对一主键双向关联Hiberna ...

  2. 解决 Springboot Unable to build Hibernate SessionFactory @Column命名不起作用

    问题: Springboot启动报错: Caused by: org.springframework.beans.factory.BeanCreationException: Error creati ...

  3. hibernate多对一双向关联

    关联是类(类的实例)之间的关系,表示有意义和值得关注的连接. 本系列将介绍Hibernate中主要的几种关联映射 Hibernate一对一主键单向关联Hibernate一对一主键双向关联Hiberna ...

  4. Hibernate中事务的隔离级别设置

    Hibernate中事务的隔离级别,如下方法分别为1/2/4/8. 在Hibernate配置文件中设置,设置代码如下

  5. Hibernate中事务声明

    Hibernate中JDBC事务声明,在Hibernate配置文件中加入如下代码,不做声明Hibernate默认就是JDBC事务. 一个JDBC 不能跨越多个数据库. Hibernate中JTA事务声 ...

  6. spring applicationContext.xml和hibernate.cfg.xml设置

    applicationContext.xml配置 <?xml version="1.0" encoding="UTF-8"?> <beans ...

  7. [原创]关于Hibernate中的级联操作以及懒加载

    Hibernate: 级联操作 一.简单的介绍 cascade和inverse (Employee – Department) Casade用来说明当对主对象进行某种操作时是否对其关联的从对象也作类似 ...

  8. hibernate的基本xml文件配置

    需要导入基本的包hibernate下的bin下的required和同bin下optional里的c3p0包下的所有jar文件,当然要导入mysql的驱动包了.下面需要注意的是hibernate的版本就 ...

  9. Maven搭建SpringMVC+Hibernate项目详解 【转】

    前言 今天复习一下SpringMVC+Hibernate的搭建,本来想着将Spring-Security权限控制框架也映入其中的,但是发现内容太多了,Spring-Security的就留在下一篇吧,这 ...

  10. 1.Hibernate简介

    1.框架简介: 定义:基于java语言开发的一套ORM框架: 优点:a.方便开发;           b.大大减少代码量;           c.性能稍高(不能与数据库高手相比,较一般数据库使用者 ...

随机推荐

  1. 超过1W字深度剖析JVM常量池(全网最详细最有深度)

    面试题:String a = "ab"; String b = "a" + "b"; a == b 是否相等 面试考察点 考察目的: 考察对 ...

  2. Centos6.8 yum报错及修复YumRepo Error: All mirror URLs are not using ftp, http[s] or file. Eg. Invalid

    问题 使用yum安装软件时报错 YumRepo Error: All mirror URLs are not using ftp, http[s] or file. Eg. Invalid relea ...

  3. MySQL:互联网公司常用分库分表方案汇总!

    一.数据库瓶颈 不管是IO瓶颈,还是CPU瓶颈,最终都会导致数据库的活跃连接数增加,进而逼近甚至达到数据库可承载活跃连接数的阈值.在业务Service来看就是,可用数据库连接少甚至无连接可用.接下来就 ...

  4. c++学习笔记(七)

    位运算和sizeof运算符 位运算 C语言中提供了一些运算符可以直接操作整数的位,称为位运算,因此位运算中的操作数都必须是整型的. 位运算的效率是比较高的,而且位运算运用好的话会达到意想不到的效果. ...

  5. RabbitMQ 处理过慢,原来是一个 SQL 缓存框架导致的 GC 频繁触发

    一:背景 1. 讲故事 上个月底,有位朋友微信找到我,说他的程序 多线程处理 RabbitMQ 时过慢,帮忙分析下什么原因,截图如下: 这问题抛出来,有点懵逼,没说CPU爆高,也没说内存泄漏,也没说程 ...

  6. Markdown For EditPlus插件使用说明(基于EditPlus快速编辑Markdonw文件,写作爱好者的福音来啦)

    Markdown For EditPlus插件使用说明 开发缘由 特点好处: 中文版使用说明 相关命令(输入字符敲空格自动输出): EditPlus常用快捷键: 相关教程: English descr ...

  7. [spojDIVCNT1]Counting Divisors

    定义 约定1:以下分数都是最简,且令$\frac{1}{0}$有意义,其大于其余分数,并称平行于$y$轴的直线斜率为$-\frac{1}{0}$ 分数加:对于分数$a=\frac{a_{1}}{a_{ ...

  8. Maven的pom.xml的格式与约束

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/20 ...

  9. Golang - 关于 proto 文件的一点小思考

    目录 前言 helloworld.proto 小思考 小结 推荐阅读 前言 ProtoBuf 是什么? ProtoBuf 是一套接口描述语言(IDL),通俗的讲是一种数据表达方式,也可以称为数据交换格 ...

  10. Python之用型号构成一个三角形代码

    #coding=utf-8 #******直角三角形*********** #左下角三角形 for i in range(1,6):     print '*'*i print "=&quo ...