日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
解說Hibernate的工作原理實(shí)例

大家可能對Hibernate 有大概了解,但Hibernate 原理到底是什么,不一定清楚,這篇文章主要通過一個(gè)實(shí)例說明Hibernate 原理。希望對大家的學(xué)習(xí)有所幫助。

我們知道如果用java連接數(shù)據(jù)庫我們首先想到的就是JDBC,那么Hibernate 原理是什么呢?hibernate可以理解為是一個(gè)中間件它負(fù)責(zé)把java程序的sql語句接收過來發(fā)送到數(shù)據(jù)庫,而數(shù)據(jù)庫返回來的信息hibernate接收之后直接生成一個(gè)對象傳給java。

在說Hibernate 原理之前,先說說Hibernate的文件吧。
假設(shè)一個(gè) student 的學(xué)生表:
sql語句:

 
 
 
  1. create table student(id Number(10),name varchar2(20)) 

接下來呢.我們需要有兩個(gè)hibernate特有的文件。一個(gè)是以.cfg.xml結(jié)尾的文件.一個(gè)是以.hbm.xml結(jié)尾的文件。 這兩個(gè)文件做什么用的呢?

 .cfg.xml 的作用就是連接數(shù)據(jù)庫,文件內(nèi)部其實(shí)就是一個(gè)由user,password,url,driver組成的一個(gè)連接庫的基本信息。

文件的內(nèi)容是這樣的:

 
 
 
  1. xml version='1.0' encoding='UTF-8'?> 
  2.   PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN"  
  3.   "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> 
  4.  
  5.  
  6.   
  7.    name="connection.username">111 property> 
  8.    name="connection.url">jdbc:oracle:thin:@127.0.0.1:1521:ris property> 
  9.    name="dialect">org.hibernate.dialect.Oracle9Dialect property> 
  10.    name="connection.password">111 property> 
  11.                  name="connection.driver_class">oracle.jdbc.driver.OracleDriver property> 
  12.  
  13.    resource="Student.hbm.xml"/> 
  14.          session-factory> 
  15. hibernate-configuration> 

這個(gè)文件的全稱應(yīng)該是"你的應(yīng)用名字.cfg.xml"。當(dāng)前例子建立的項(xiàng)目名稱是one.cfg.xml 。

簡單分析一下這個(gè)文件:

包含的是程序里面的 configuration 的實(shí)例的信息。通過這個(gè)實(shí)例的方法configure我們可以從 mapping 里得到對應(yīng)的表的信息和類的信息。

這個(gè)標(biāo)簽是我們在程序里通過 configure 的方法 BuildSessionFactory 所得到的一個(gè) SessionFactory 對象,這個(gè)對象可以理解為一個(gè) statement ,我們對數(shù)據(jù)庫的所有操作都是通過它的一系列方法來實(shí)現(xiàn)的。

里面的那些 property 是一些連接需要的東西。其中dialect 這個(gè)是hibernate的方言屬性值,對于不同的數(shù)據(jù)庫,方言的值dialect是不同的,那么下面就列出在不同的數(shù)據(jù)庫中如何設(shè)置該dialect值(參見下表):   

RDBMS

方言

DB2

org.hibernate.dialect.DB2Dialect

DB2 AS/400

org.hibernate.dialect.DB2400Dialect

DB2 OS390

org.hibernate.dialect.DB2390Dialect

PostgreSQL

org.hibernate.dialect.PostgreSQLDialect

MySQL

org.hibernate.dialect.MySQLDialect

MySQL with InnoDB

org.hibernate.dialect.MySQLInnoDBDialect

MySQL with MyISAM

org.hibernate.dialect.MySQLMyISAMDialect

Oracle (any version)

org.hibernate.dialect.OracleDialect

Oracle 9i/10g

org.hibernate.dialect.Oracle9Dialect

Sybase

org.hibernate.dialect.SybaseDialect

Sybase Anywhere

org.hibernate.dialect.SybaseAnywhereDialect

Microsoft SQL Server

org.hibernate.dialect.SQLServerDialect

SAP DB

org.hibernate.dialect.SAPDBDialect

Informix

org.hibernate.dialect.InformixDialect

HypersonicSQL

org.hibernate.dialect.HSQLDialect

Ingres

org.hibernate.dialect.IngresDialect

Progress

org.hibernate.dialect.ProgressDialect

Mckoi SQL

org.hibernate.dialect.MckoiDialect

Interbase

org.hibernate.dialect.InterbaseDialect

Pointbase

org.hibernate.dialect.PointbaseDialect

FrontBase

org.hibernate.dialect.FrontbaseDialect

Firebird

org.hibernate.dialect.FirebirdDialect

跟住繼續(xù)講 Student.hbm.xml 這個(gè)文件。這個(gè)文件是對數(shù)據(jù)庫的表的映射文件,我們用這個(gè)文件指出哪個(gè)類對應(yīng)著哪個(gè)表,而且還指出哪個(gè)類中的屬性對應(yīng)著表中的哪個(gè)字段。
文件的內(nèi)容是這樣的:

 
 
 
  1. xml version="1.0"?> 
  2.   PUBLIC"-//Hibernate/Hibernate Mapping DTD 3.0//EN"  
  3.   "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> 
  4.  
  5.  
  6.   name="src.Student" table="student"> 
  7.    name="id" column="id"> 
  8.     class="increment"/> 
  9.    id> 
  10.    name="name" column="name"/> 
  11.   class> 
  12. hibernate-mapping> 

到此這個(gè)文件就結(jié)束了。特別說一下這個(gè)id 的問題。我們看到文件里面有個(gè) ,這個(gè)是什么呢?這個(gè)是可以實(shí)現(xiàn)自動 id 增加,也就是說如果我們往數(shù)據(jù)庫中插入一個(gè) name 那么就id自動加1 。

這個(gè)文件解釋一下了 這個(gè)所包含的就是我們前一個(gè)文件里面說的mapping。我們在java類中configure得到的mapping就是從這個(gè)文件里面讀取出來的。類如果帶包的話一定要帶包名(推薦一切寫的類都要帶包).包名和類名要注意.包名小寫,類名的第一個(gè)大寫。我是怕出錯(cuò),這里提醒大家一下, 這個(gè)就是先指定了類對應(yīng)的表。然后里面的那些就是指定表中的字段與類中的屬性的對應(yīng)關(guān)系了。

到這里這兩個(gè)特殊的文件就介始完了。下面就開始講我們的 java 類了。主要有兩個(gè):一個(gè)是Pojo類,一個(gè)是我們的Test類。

Pojo類其實(shí)就是簡單的一個(gè)javaBean。(Plain Old Java Objects, 簡單潔凈Java對象)??聪旅娴拇a:

 
 
 
  1. package src;  
  2.  
  3.  public class Student{  
  4.  
  5.     private int id;  
  6.     private String name;  
  7.  
  8.     public void setId(int id){  
  9.        this.id=id;  
  10.     }  
  11.  
  12.  
  13.     public void setName(String name){  
  14.        this.name=name;  
  15.     }  
  16.  
  17.     public int getId(){  
  18.      return id;  
  19.     }  
  20.  
  21.     public String getName(){  
  22.      return name;  
  23.     }  
  24.  }  

就是這么簡單的一個(gè)類。就是和數(shù)據(jù)庫的字段對應(yīng)然后取值的。

下面是我們關(guān)鍵的Test類:

 
 
 
  1. package src;  
  2.  
  3. import org.hibernate.*;  
  4. import org.hibernate.cfg.*;  
  5.  
  6. public class Test{  
  7.    public static void main(String bb[]){  
  8.       try{  
  9.          SessionFactory sf=new Configuration().configure().BuildSessionFactory();  
  10.          Session s=sf.opension();  
  11.          Transaction ts=s.beginTransaction();  
  12.          for(int i=0;i<3;i++){  
  13.             Student st=new Student();  
  14.             st.setName("begin go "+ i);  
  15.             s.save(st);  
  16.         }  
  17.          ts.commit();  
  18.          s.close();  
  19.        }catch(Exception e){  
  20.          e.printStackTrace();  
  21.       }  
  22.    }  
  23. }  

這里的第一句 SessionFactory sf=new Configuration().configure().BuildSessionFactory(); 得到configuration的實(shí)例.這個(gè)開始要和最前面的哪個(gè).cfg.xml對應(yīng)著看了。

我們?nèi)〉脤?shí)例,然后通過configure()讀取mapping對應(yīng)的.hbm.xml文件的信息。然后我們通過BuildSessionFactory得到SessionFactory對象,然后我們在通過opensession() 建立連接 .Session 就是指一個(gè)session被建立。這個(gè)需要有servlet的基礎(chǔ)理解,這里等于是一個(gè)connection被建立好。

下面通過session對象開啟事務(wù)(Transaction)這個(gè)相當(dāng)于conn.setAutoCommit(false);先不遞交最后通過另外一個(gè)方法遞交。我們看到下面我們循環(huán)里把咱們寫好的Student實(shí)例化了。既然實(shí)例化了我們就能用里面的方法了。

每次都要session來save一下。一個(gè)對象set之后要保存,很好理解吧,保存在了session中。最后遞交commit();  這個(gè)方法實(shí)際上是實(shí)現(xiàn)了兩個(gè)作用

 
 
 
  1. conn.commit();    
  2.  conn.setAutoCommit(true);  

這樣才能把我們的數(shù)據(jù)放進(jìn)數(shù)據(jù)庫中。  很奇怪沒有sql語句吧.最后提醒一下.想想hibernate的特性.我們對數(shù)據(jù)庫的操作就是對對象的操作.這就是OR-Mapping。呵呵,實(shí)例分析結(jié)束。


分享標(biāo)題:解說Hibernate的工作原理實(shí)例
網(wǎng)站鏈接:http://m.5511xx.com/article/djidecd.html