亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時(shí)間:2017年06月07日 08:43:07   投稿:jingxian  
下面小編就為大家?guī)?lái)一篇hibernate框架環(huán)境搭建具體步驟(介紹)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

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

二. hibernate框架的搭建

1.導(dǎo)包

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

  mysql驅(qū)動(dòng)包.

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

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屬性:對(duì)應(yīng)的表名
   -->
  <class name="Customer" table="cst_customer" >
  <!-- id:映射主鍵屬性名(OID)與主鍵列對(duì)應(yīng)關(guān)系
      name屬性: OID名稱
      column屬性(可選):主鍵列名,默認(rèn)值就是name屬性值
      length屬性(可選):指定屬性長(zhǎng)度.默認(rèn)值使用數(shù)據(jù)庫(kù)對(duì)應(yīng)列長(zhǎng)度
      type屬性(可選):指定當(dāng)前列(屬性)的類型.默認(rèn)值會(huì)根據(jù)數(shù)據(jù)庫(kù)類型自動(dòng)指定類型.
        type="long"        hibernate類型
        type="java.lang.Long"  java類型
        <column name="cust_id" sql-type="bigint" ></column> 數(shù)據(jù)庫(kù)類型
   -->
    <id name="cust_id" >
      <!--主鍵生成策略 
        increment:hibernate每次保存數(shù)據(jù)是,會(huì)查詢數(shù)據(jù)庫(kù)中最大的值,在最大值的基礎(chǔ)上加1作為新的主鍵值(測(cè)試時(shí)使用)
      identity:主鍵自增,有數(shù)據(jù)庫(kù)負(fù)責(zé)生成主鍵值
      sequence:序列,Oracle時(shí)使用
      hilo:高低位算法,適用于既不支持自增也不支持序列的庫(kù)(用不著)
      native:identity|sequence|hilo自動(dòng)三選一
      uuid:主鍵類型為字符串是使用.
      assigned:有我們手動(dòng)指定ID值
        -->
      <generator class="native"></generator>
    </id>
    <!-- property:映射非主鍵屬性名與非主鍵列對(duì)應(yīng)關(guān)系
      name屬性: 屬性名
      column屬性(可選):非主鍵列名,默認(rèn)值就是name屬性值
      length屬性(可選):指定屬性長(zhǎng)度.默認(rèn)值使用數(shù)據(jù)庫(kù)對(duì)應(yīng)列長(zhǎng)度
      type屬性(可選):指定當(dāng)前列(屬性)的類型.默認(rèn)值會(huì)根據(jù)數(shù)據(jù)庫(kù)類型自動(dòng)指定類型.
        type="long"        hibernate類型
        type="java.lang.Long"  java類型
        <column name="cust_id" sql-type="bigint" ></column> 數(shù)據(jù)庫(kù)類型
   -->
    <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對(duì)象配置的 -->
    <session-factory>
    <!-- 必選配置
    
      //方言
      //所有數(shù)據(jù)庫(kù)的sql語(yǔ)句都是基于SQL99標(biāo)準(zhǔn)的
      //每個(gè)數(shù)據(jù)庫(kù)遵循SQL99標(biāo)準(zhǔn)的同時(shí),也會(huì)擴(kuò)充一部分SQL語(yǔ)句.這些標(biāo)準(zhǔn)之外的sql語(yǔ)句叫做方言  mysql方言: limit 0,5
      //注意:mysql方言類一共有3個(gè).一定要選最短的
      #hibernate.dialect org.hibernate.dialect.MySQLDialect
      //數(shù)據(jù)庫(kù)驅(qū)動(dòng)
      #hibernate.connection.driver_class com.mysql.jdbc.Driver
      //數(shù)據(jù)庫(kù)連接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>
    <!-- 可選配置 
      //是否在控制臺(tái)顯示hibernate生成的sql
      hibernate.show_sql true
      //是否對(duì)顯示到控制臺(tái)的sql語(yǔ)句格式化
      hibernate.format_sql true
      //自動(dòng)建表
      # create(測(cè)試時(shí)使用)    : 自動(dòng)建表,每次啟動(dòng)hibernate的時(shí)候都會(huì)自動(dòng)建表.
      # create-drop(測(cè)試時(shí)使用)   : 自動(dòng)建表,每次啟動(dòng)hibernate的時(shí)候都會(huì)自動(dòng)建表.釋放資源時(shí)會(huì)將所有表刪除.
      # update(常用)  : 自動(dòng)建表,有表就不會(huì)再創(chuàng)建,如果已經(jīng)存在的表不完全匹配.會(huì)自動(dòng)修改表結(jié)構(gòu).
      # validate    : 校驗(yàn)表結(jié)構(gòu).不會(huì)自動(dòng)建表.每次hibernate啟動(dòng)時(shí)都會(huì)檢查表結(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ù)庫(kù)隔離級(jí)別 
        ## specify a JDBC isolation level
        #hibernate.connection.isolation 4
        mysql 默認(rèn)級(jí)別是4
        Oracle 默認(rèn)級(jí)別是2
      -->
      <property name="hibernate.connection.isolation">4</property>
      <!-- 配置session與當(dāng)前線程綁定 -->
      <property name="hibernate.current_session_context_class">thread</property>
      
      
    <!-- 映射引入配置 
        resource屬性:填寫引入映射文件的路徑. 相對(duì)于src目錄下.
    -->
      <mapping resource="cn/itcast/domain/Customer.hbm.xml" />
    </session-factory>
  </hibernate-configuration>

以上這篇hibernate框架環(huán)境搭建具體步驟(介紹)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 使用nacos實(shí)現(xiàn)自定義文本配置的實(shí)時(shí)刷新

    使用nacos實(shí)現(xiàn)自定義文本配置的實(shí)時(shí)刷新

    我們都知道,使用Nacos時(shí),如果將Bean使用@RefreshScope標(biāo)注之后,這個(gè)Bean中的配置就會(huì)做到實(shí)時(shí)刷新,本文給大家介紹了如何使用nacos實(shí)現(xiàn)自定義文本配置的實(shí)時(shí)刷新,需要的朋友可以參考下
    2024-05-05
  • 基于SpringBoot制作一個(gè)PDF切圖小工具

    基于SpringBoot制作一個(gè)PDF切圖小工具

    這篇文章主要為大家詳細(xì)介紹了如何基于SpringBoot制作一個(gè)PDF切圖小工具,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-01-01
  • Jackson常用方法以及jacksonUtil工具類詳解

    Jackson常用方法以及jacksonUtil工具類詳解

    這篇文章主要介紹了Jackson常用方法以及jacksonUtil工具類詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • 如何在SpringBoot中添加攔截器忽略請(qǐng)求URL當(dāng)中的指定字符串

    如何在SpringBoot中添加攔截器忽略請(qǐng)求URL當(dāng)中的指定字符串

    這篇文章主要介紹了在SpringBoot中添加攔截器忽略請(qǐng)求URL當(dāng)中的指定字符串,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-08-08
  • Spring的@Bean和@Autowired組合使用詳解

    Spring的@Bean和@Autowired組合使用詳解

    這篇文章主要介紹了Spring的@Bean和@Autowired組合使用詳解,Spring的@Bean注解用于告訴方法,產(chǎn)生一個(gè)Bean對(duì)象,然后這個(gè)Bean對(duì)象交給Spring管理,產(chǎn)生這個(gè)Bean對(duì)象的方法Spring只會(huì)調(diào)用一次隨后會(huì)將這個(gè)Bean對(duì)象放在自己的IOC容器,需要的朋友可以參考下
    2024-01-01
  • 關(guān)于兩個(gè)BeanUtils.copyProperties()的用法及區(qū)別

    關(guān)于兩個(gè)BeanUtils.copyProperties()的用法及區(qū)別

    這篇文章主要介紹了關(guān)于兩個(gè)BeanUtils.copyProperties()的用法及區(qū)別說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • Java序列化與反序列化

    Java序列化與反序列化

    這篇文章主要介紹了Java的序列化與反序列化,序列化把一個(gè)對(duì)象Java Object變?yōu)橐粋€(gè)二進(jìn)制字節(jié)序列byte[];反序列化就是把一個(gè)二進(jìn)制字節(jié)序列byte[]變?yōu)镴ava對(duì)象Java Object。感興趣的小伙伴可以參考閱讀
    2023-04-04
  • 解決JDK21中用不了TimeUtild問(wèn)題

    解決JDK21中用不了TimeUtild問(wèn)題

    在使用TimeUtil時(shí),可能因?yàn)镮DE版本不兼容導(dǎo)致問(wèn)題,升級(jí)IDEA到2023.2以上版本可解決此問(wèn)題,詳細(xì)步驟可以通過(guò)評(píng)論區(qū)索取安裝包或直接從官網(wǎng)下載,分享個(gè)人經(jīng)驗(yàn),希望對(duì)大家有幫助
    2024-10-10
  • 深入理解Java三大特性中的多態(tài)

    深入理解Java三大特性中的多態(tài)

    多態(tài)性是對(duì)象多種表現(xiàn)形式的體現(xiàn)。在面向?qū)ο笾校畛R?jiàn)的多態(tài)發(fā)生在使用父類的引用來(lái)引用子類的對(duì)象。下面這篇文章主要給大家深入的介紹了Java三大特性中多態(tài)的相關(guān)資料,有需要的朋友可以參考借鑒,下面來(lái)一起看看吧。
    2017-01-01
  • Java如何調(diào)用TSC打印機(jī)進(jìn)行打印詳解

    Java如何調(diào)用TSC打印機(jī)進(jìn)行打印詳解

    這篇文章主要給大家介紹了關(guān)于Java如何調(diào)用TSC打印機(jī)進(jìn)行打印的相關(guān)資料,文中介紹了三種方法,分別是兩種后臺(tái)打印以及JS打印 ,三種方法都給出了詳細(xì)的示例代碼,需要的朋友可以參考借鑒,下面來(lái)一起看看吧
    2018-07-07

最新評(píng)論