hibernate框架環(huán)境搭建具體步驟(介紹)

一. 概述:hibernate框架是作用于dao層的,實(shí)現(xiàn)對數(shù)據(jù)的持久化保存.通過面向?qū)ο蟮姆绞讲僮鲾?shù)據(jù)庫。

巴彥網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián)建站,巴彥網(wǎng)站設(shè)計制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為巴彥千余家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\外貿(mào)營銷網(wǎng)站建設(shè)要多少錢,請找那個售后服務(wù)好的巴彥做網(wǎng)站的公司定做!

二. hibernate框架的搭建

1.導(dǎo)包

  lib目錄下的required文件夾下的所有jar包.

  MySQL驅(qū)動包.

2.創(chuàng)建數(shù)據(jù)庫于表.

3.創(chuàng)建實(shí)體類.

4.創(chuàng)建實(shí)體映射文件(以crm練習(xí)Customer類為例)

  實(shí)體類名.hbm.xml

  引入約束文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
  "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
  "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<!-- 根元素
    package(可選):填寫包名.后面凡是需要完整類名的地方,都可以省略包名了.
 -->
<hibernate-mapping package="cn.itcast.domain" >
  <!-- class:映射類與表的關(guān)系
      name屬性:實(shí)體屬性名
      table屬性:對應(yīng)的表名
   -->
  <class name="Customer" table="cst_customer" >
  <!-- id:映射主鍵屬性名(OID)與主鍵列對應(yīng)關(guān)系
      name屬性: OID名稱
      column屬性(可選):主鍵列名,默認(rèn)值就是name屬性值
      length屬性(可選):指定屬性長度.默認(rèn)值使用數(shù)據(jù)庫對應(yīng)列長度
      type屬性(可選):指定當(dāng)前列(屬性)的類型.默認(rèn)值會根據(jù)數(shù)據(jù)庫類型自動指定類型.
        type="long"        hibernate類型
        type="java.lang.Long"  java類型
        <column name="cust_id" sql-type="bigint" ></column> 數(shù)據(jù)庫類型
   -->
    <id name="cust_id" >
      <!--主鍵生成策略 
        increment:hibernate每次保存數(shù)據(jù)是,會查詢數(shù)據(jù)庫中最大的值,在最大值的基礎(chǔ)上加1作為新的主鍵值(測試時使用)
      identity:主鍵自增,有數(shù)據(jù)庫負(fù)責(zé)生成主鍵值
      sequence:序列,Oracle時使用
      hilo:高低位算法,適用于既不支持自增也不支持序列的庫(用不著)
      native:identity|sequence|hilo自動三選一
      uuid:主鍵類型為字符串是使用.
      assigned:有我們手動指定ID值
        -->
      <generator class="native"></generator>
    </id>
    <!-- property:映射非主鍵屬性名與非主鍵列對應(yīng)關(guān)系
      name屬性: 屬性名
      column屬性(可選):非主鍵列名,默認(rèn)值就是name屬性值
      length屬性(可選):指定屬性長度.默認(rèn)值使用數(shù)據(jù)庫對應(yīng)列長度
      type屬性(可選):指定當(dāng)前列(屬性)的類型.默認(rèn)值會根據(jù)數(shù)據(jù)庫類型自動指定類型.
        type="long"        hibernate類型
        type="java.lang.Long"  java類型
        <column name="cust_id" sql-type="bigint" ></column> 數(shù)據(jù)庫類型
   -->
    <property name="cust_name" column="cust_name" ></property>
    <property name="cust_source" ></property>
    <property name="cust_industry" column="cust_industry" ></property>
    <property name="cust_level" column="cust_level" ></property>
    <property name="cust_phone" column="cust_phone" ></property>
    <property name="cust_mobile" column="cust_mobile" ></property>
  </class>
</hibernate-mapping>

創(chuàng)建主配置文件

hibernate.cfg.xml(在src下)

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
  "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
  "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
  <!-- 根元素 -->
  <hibernate-configuration>
    <!-- 以下都是為sessionFactory對象配置的 -->
    <session-factory>
    <!-- 必選配置
    
      //方言
      //所有數(shù)據(jù)庫的sql語句都是基于SQL99標(biāo)準(zhǔn)的
      //每個數(shù)據(jù)庫遵循SQL99標(biāo)準(zhǔn)的同時,也會擴(kuò)充一部分SQL語句.這些標(biāo)準(zhǔn)之外的sql語句叫做方言  mysql方言: limit 0,5
      //注意:mysql方言類一共有3個.一定要選最短的
      #hibernate.dialect org.hibernate.dialect.MySQLDialect
      //數(shù)據(jù)庫驅(qū)動
      #hibernate.connection.driver_class com.mysql.jdbc.Driver
      //數(shù)據(jù)庫連接url
      #hibernate.connection.url jdbc:mysql:///test
      //連接用戶名
      #hibernate.connection.username gavin
      //連接密碼
      #hibernate.connection.password
     -->
      <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
      <property name="hibernate.connection.url">jdbc:mysql:///hibernate_54</property>
      <property name="hibernate.connection.username">root</property>
      <property name="hibernate.connection.password">1234</property>
      <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
    <!-- 可選配置 
      //是否在控制臺顯示hibernate生成的sql
      hibernate.show_sql true
      //是否對顯示到控制臺的sql語句格式化
      hibernate.format_sql true
      //自動建表
      # create(測試時使用)    : 自動建表,每次啟動hibernate的時候都會自動建表.
      # create-drop(測試時使用)   : 自動建表,每次啟動hibernate的時候都會自動建表.釋放資源時會將所有表刪除.
      # update(常用)  : 自動建表,有表就不會再創(chuàng)建,如果已經(jīng)存在的表不完全匹配.會自動修改表結(jié)構(gòu).
      # validate    : 校驗(yàn)表結(jié)構(gòu).不會自動建表.每次hibernate啟動時都會檢查表結(jié)構(gòu)是否正確.
                    //不正確=>拋出異常.
    -->
      <property name="hibernate.show_sql">true</property>
      <property name="hibernate.format_sql">true</property>
      
      <property name="hibernate.hbm2ddl.auto">update</property>
      
      <!-- 指定數(shù)據(jù)庫隔離級別 
        ## specify a JDBC isolation level
        #hibernate.connection.isolation 4
        mysql 默認(rèn)級別是4
        Oracle 默認(rèn)級別是2
      -->
      <property name="hibernate.connection.isolation">4</property>
      <!-- 配置session與當(dāng)前線程綁定 -->
      <property name="hibernate.current_session_context_class">thread</property>
      
      
    <!-- 映射引入配置 
        resource屬性:填寫引入映射文件的路徑. 相對于src目錄下.
    -->
      <mapping resource="cn/itcast/domain/Customer.hbm.xml" />
    </session-factory>
  </hibernate-configuration>

以上這篇hibernate框架環(huán)境搭建具體步驟(介紹)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持創(chuàng)新互聯(lián)。

網(wǎng)站題目:hibernate框架環(huán)境搭建具體步驟(介紹)
地址分享:http://muchs.cn/article16/gjsjgg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供ChatGPT、企業(yè)網(wǎng)站制作、網(wǎng)站收錄、服務(wù)器托管、用戶體驗(yàn)、網(wǎng)站營銷

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化