一、hibernate简单了解:

   ⑴、hibernate一个java领域里面的一个持久化的ORM框架。

     持久化:就是对对象的数据修改,hibernate会把修改的数据同步到数据库中。

     ORM:Object Relation Mapping 对象关系映射。把数据库中的表映射成java中的一个个对象(POJO),然后hibernate通过对对象的操作来对表进行操作。 

   ⑵、hibernate是对数据数据库的进一步的封装,hibernate的底层还是JDBC。 

 二、hibernate搭建:

   在之前,我们已经搭建好了struts2和spring的环境,现在在这二者的基础之上对数据库进行进一步的封装,也就是在项目中加入hibernate。

   ⑴、首先,下载hibernate 下载地址:http://hibernate.org/orm/ ,下载完解压后:hibernate-release-5.2.2.Final—>>lib—>>required,找到这个目录中的所有jar包复制到项目中即可。同时在同级目录中有其他的jar可以适当的了解,比如:optional目录中有c3p0的jar,后面数据库连接池需要使用到。

    

   ⑵、编写hibernate.cfg.xml文件:

     ①、在你的项目src目录下添加一个hibernate.cfg.xml文件,文件名可以任意,但需是XXX.cfg.xml类型。

     ②、声明dtd:(根据你下载的版本来确定dtd。)

<!DOCTYPE hibernate-configuration
PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

     ③、具体编写hibernate.configuration

<hibernate-configuration>

  <!--设置sessionFactory-->  
<session-factory>
<!-- 配置相关的数据库基本信息 -->
<!-- 数据库驱动 -->
<property name="connection.driver_class">com.microsoft.sqlserver.jdbc.SQLServerDriver</property>
<!-- 数据库访问路径 -->
<property name="connection.url">jdbc:sqlserver://localhost:1433;DatabaseName = webLastExam_20160727</property>
<!-- 登录用户名 -->
<property name="connection.username">sa</property>
<!-- 登录密码 -->
<property name="connection.password">password</property> <!-- 配置hibernate的基本信息 -->
<!-- 配置hibernate使用的数据库方言 -->
<property name="dialect">org.hibernate.dialect.SQLServer2008Dialect</property>


<!-- 设置数据库连接池的大小 -->
<property name="connection.pool_size">5</property>


<!-- 执行操作时候是否在控制台打印sql语句 -->
<property name="show_sql">true</property> <!-- 是否进行格式化sql语句,指的是在控制台中输出的sql语句是否换行 -->
<property name="format_sql">true</property> <!--生成数据表的策略-->
<property name="hbm2ddl.auto">update</property> <!-- 设置hibernate的映射文件 -->
<mapping resource="entity/BookCard.hbm.xml"/>
</session-factory>
</hibernate-configuration>

      ·这里配置的session-Factory中的数据库信息本来实在util.MyConnectionImp中定义的,如果在util.MyConnectionImp定义好数据的信息,那么用户的数据库一切换就要修改这里的代码,所以需要把这个获取连接的事情交给hibernate去管理,这样就避免了直接修改代码,只要修改配置文件即可。

       ·这里需要设置的属性有:

        数据库驱动、数据库访问路径、用户名、密码、数据库方言、连接池大小、hibernate的映射文件(后面会讲)等。  

        其中  <property name="hbm2ddl.auto">update</property> 这个属性如果设置为create,那么之前的数据库中的数据在电脑开机之后删除。

   ⑶、编写hibernate的映射文件- entityName.hbm.xml :

      ①、声明dtd:根据你下载的版本来确定dtd。)

<!DOCTYPE hibernate-mapping
PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

      ②、编写hibernate-mapping

<hibernate-mapping>

    <class name="entity_name" table="tabel_name">

        <id name="entity_prop_name" type="integer" >
<column name="column_name"></column>
<generator class="native" />
</id>
<property name="entity_prop_name" type="string">
        <column name="column_name"></column>
    </property> </class>
</hibernate-mapping>

          ·其中,class标签中的name属性值对应需要映射的实体类的名字,并且是 "包名.类名" 形式。table属性则是需要通过映射这个实体类到数据库中的表名。

          ·其次,id标签设置的是数据库表中的主键,name属性对应实体类中需要做主键的成员变量名,type属性是这个成员变量的数据类型,而且这个类型是hibernate映射类型,具体参考映射对照表,column标签中的name顾名思义就是表中的名字了。generator标签中的class属性设置为native,则是为根据不同的底层数据库采用不同的主键生成方式。由于Hibernate会根据底层数据库采用不同的映射方式,因此便于程序移植,项目中如果用到多个数据库时,可以使用这种方式。 

               

    ⑷、在dao中进行sessionFactory的最后配置:

     ①、获取SessionFactory

       一种是手动new出一个Configuration抽象工厂,然后用这个抽象工工厂创建SessionFactory。这种需要hibernate的XXX.cfg.xml配置,也就是现在我们讲的这种。另外一种是使用spring的bean来new一个SessionFactory,然后注入到dao定义的成员变量SessionFactory中。现在我们先演示第一种:

        Ⅰ、获取SessionFactory:如果下面的configure()方法不传入参数那么就默认是hibernate.cfg.xml文件。

<!--获取SessionFactory-->
SessionFactory sessionFactory = new Configuration().configure("mySQLHibernate.cfg.xml").buildSessionFactory(); <!--获取Session对象-->
Session session = sessionFactory.openSession();

        Ⅱ、下面就可执行curd操作啦,示例一个查询表中所有数据

<!--查询表中所有数据-->
Query query = session.createQuery("from BookCard"); <!--把查询出来的数据放到集合中-->
List<BookCard> list = query.getResultList();

      讲解结束,谢谢浏览!

ssh(sturts2_spring_hibernate) 框架搭建之hibernate1的更多相关文章

  1. ssh(sturts2_spring_hibernate) 框架搭建之hibernate2

    一.今天要进行解答的是对上次hibernate1进行进一步的完善,这次第一是进一步使用spring注入一个SessionFactory实例,避免了自己new实例:第二是应用数据库池(c3p0). 二. ...

  2. ssh(sturts2_spring_hibernate) 框架搭建之struts2

    一.struts2完整流程的逻辑(整体的概述) 首先,用户在地址栏中输入你的项目访问路径,然后这个请求会发送到服务器,之后服务器发现在web.xml中配置了一个filter过滤器,并且这个过滤器需要对 ...

  3. ssh(sturts2_spring_hibernate) 框架搭建之spring

    一.spring总结: ⑴.spring是一个轻量级的JAVA开发框架,主要的作用是用来管理实例(可以解决JAVA类中new对象的问题,节省内存资源.)和降低代码之间的耦合性,促进代码模块化. ⑵.促 ...

  4. ssh(sturts2_spring_hibernate) 框架搭建之JPA代替hibernate

    一.JPA用来替代hibernate ⒈JPA的全称是JAVA Persistence API.指的是JPA通过注解或者是XML描述对象—关系表的映射关系,并且将运行的实体对象持久化数据库中. ⒉JP ...

  5. 新手SSH基础框架搭建

    SSH 为 struts+spring+hibernate的一个集成框架,是目前较流行的一种Web应用程序开源框架. 首先我们先了解SSH的框架所需的包和基本概念: 一.下面我们先来了解一下strut ...

  6. SSH基本框架搭建后的简化

    对于SSh框架的简化,我们可以从下面几个方面来剖析: 1.实体类entity:在这里我们需要将数据库和实体类进行关联,在简化之前,我们需要在entity包里面加入一份.xml配置文件 例如原码---- ...

  7. 【Java EE 学习 69 中】【数据采集系统第一天】【SSH框架搭建】

    经过23天的艰苦斗争,终于搞定了数据采集系统~徐培成老师很厉害啊,明明只是用了10天就搞定的项目我却做了23天,还是模仿的...呵呵,算了,总之最后总算是完成了,现在该好好整理该项目了. 第一天的内容 ...

  8. SSH(Struts2+Spring+Hibernate)框架搭建流程<注解的方式创建Bean>

    此篇讲的是MyEclipse9工具提供的支持搭建自加包有代码也是相同:用户登录与注册的例子,表字段只有name,password. SSH,xml方式搭建文章链接地址:http://www.cnblo ...

  9. eclipse中SSH三大框架环境搭建<三>

    相关链接: eclipse中SSH三大框架环境搭建<一> eclipse中SSH三大框架环境搭建<二> 引言:通过上两篇文章我们已经可以掌握struts2和spring的环境的 ...

随机推荐

  1. <转>C Runtime Library(MSVCRT)来历

    (转载)C Runtime Library(MSVCRT)来历   msvcrt.dll (名称:Microsoft C Runtime Library)提供了printf,malloc,strcpy ...

  2. Python 学习---------Day2

    第四章 介绍Python对象类型为什么使用内置类型 内置对象使程序更容易编写 内置对象是拓展的组件 内置对象往往比定制的数据结构更有效率 内置对象是语言标准的一部分Python的核心数据类型 数字 字 ...

  3. 使用TableViewRow完成下拉菜单效果

    在TableViewRow标签中增加一个属性opened(自己定义的)=true or false 用于标记当前row的状态 ​    ​然后用table_view.deleteRow()方法  参数 ...

  4. EasyUI需注意的问题01

    一.EasyUI-Datagrid分页 在创建数据表格(DataGrid)的时候,通过设置'pagination' 属性为 true,可以在数据表格的底部生成一个分页工具栏. <table id ...

  5. Codeforces Zip-line 650D 345Div1D(LIS)

    传送门 大意:给出一个序列,求修改一个数过后的最长上升子序列. 思路:可以用主席树在线搞,也可以用树状数组离线搞,明显后者好写得多.我们首先读取所有的询问,然后就把询问绑在给出的位置,然后我们正向做一 ...

  6. Create Oracle Enterprise Manager repository data after restore a database from another server

    1. Set password for SYS in password file: orapwd file=$ORACLE_HOME/dbs/orapw<ORACLE_SID> 2. Dr ...

  7. 三星(SAMSUNG)910S3L-K04 安装win7的BIOS设置

    三星(SAMSUNG)910S3L-K04 开机后连续点击F2进入BIOS,再进入BOOT.将SECURE BOOT CONTROL点成disabled,将OS MODE SELECTION选为uef ...

  8. 在WPF的WebBrowser控件中屏蔽脚本错误的提示

    在WPF中使用WebBrowser控件显示网页时,经常会报脚本错误的提示,如何屏蔽掉这些错误提示呢.方法是定义如下方法: public void SuppressScriptErrors(WebBro ...

  9. react-router+webpack+gulp路由实例

    背景:新项目要开始了,有一种想要在新项目中使用react的冲动,应该也是一个单页面的应用,单页应用就涉及到一个路由的问题.于是最近在网上找了蛮多关于react-router的文章,也遇到了许多的坑,经 ...

  10. windows phone 8.1教务在线客户端(后续)

    经过了一番折腾,这个wp教务在线算是告一段落了,其实原理很简单,就是post方式访问登陆页面返回cookie,然后带着这个cookie用get方式继续访问你想要访问并取回内容的页面,而且httpcli ...