成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

八步詳解Hibernate的搭建及使用

開發 后端
本文通過了八個步驟以及一些實例添加用戶來介紹Hibernate的搭建和使用,真切的介紹了hibernate的基本用法,其中好多優點等待我們自己去發現,比如hibernate中的緩存機制,映射方案。

上篇博客已經把Hibernate概念和其中的核心接口介紹,下面舉個實例添加用戶來介紹Hibernate如何使用。

1.創建普通的java項目。

因為Hibernate是一個輕量級的框架,不像servlet,還必須需要tomcat的支持,Hibernate只要jdk支持即可。

2.引入jar包。

可以在項目中直接引入jar包,在:項目--->屬性--->然后如下圖:

另一種辦法就是引入庫,相當于一個文件夾,把所有的jar包放到自己新建的文件夾中。在:窗體-->選項-->然后如下圖:

3.提供Hibernate的配置文件。hibernate.cfg.xml文件。完成相應的配置。

  1. <hibernate-configuration>  
  2.  
  3. <session-factory>  
  4.  
  5. <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>  
  6.  
  7. <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/hibernate_first</property>  
  8.  
  9. <property name="hibernate.connection.username">root</property>  
  10.  
  11. <property name="hibernate.connection.password">bjpowernode</property>  
  12.  
  13. <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>  
  14.  
  15. </session-factory>  
  16.  
  17. </hibernate-configuration>  

在這里連接mysql數據庫,解釋一下上面的標簽。按照順序來依次解釋:第一個是連接mySql的驅動;第二個是連接的url;url后面的hibernate_first是數據庫名字;第三個是和第四個分別是用戶名和密碼。第五個是方言。因為 hibernate對數據庫封裝,對不同的數據庫翻譯成不同的形式,比如drp中的分頁,若是使用oracle數據庫,則翻譯成sql語句三層嵌套。若是使用mySql數據庫,則翻譯成limit語句。

4.建立實體User類:

  1. package com.bjpowernode.hibernate;  
  2.  
  3. import java.util.Date;  
  4.  
  5. public class User {  
  6.  
  7.     private String id;  
  8.       
  9.     private String name;  
  10.       
  11.     private String password;  
  12.       
  13.     private Date createTime;  
  14.       
  15.     private Date expireTime;  
  16.  
  17.     public String getId() {  
  18.         return id;  
  19.     }  
  20.  
  21.     public void setId(String id) {  
  22.         this.id = id;  
  23.     }  
  24.  
  25.     public String getName() {  
  26.         return name;  
  27.     }  
  28.  
  29.     public void setName(String name) {  
  30.         this.name = name;  
  31.     }  
  32.  
  33.     public String getPassword() {  
  34.         return password;  
  35.     }  
  36.  
  37.     public void setPassword(String password) {  
  38.         this.password = password;  
  39.     }  
  40.  
  41.     public Date getCreateTime() {  
  42.         return createTime;  
  43.     }  
  44.  
  45.     public void setCreateTime(Date createTime) {  
  46.         this.createTime = createTime;  
  47.     }  
  48.  
  49.     public Date getExpireTime() {  
  50.         return expireTime;  
  51.     }  
  52.  
  53.     public void setExpireTime(Date expireTime) {  
  54.         this.expireTime = expireTime;  
  55.     }  
  56. }  

5.建立User.hbm.xml,此文件用來完成對象與數據庫表的字段的映射。也就是實體類的那些字段需要映射到數據庫表中呢。

  1. <?xml version="1.0"?>  
  2. <!DOCTYPE hibernate-mapping PUBLIC   
  3.     "-//Hibernate/Hibernate Mapping DTD 3.0//EN" 
  4.     "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">  
  5. <hibernate-mapping>  
  6.     <class name="com.bjpowernode.hibernate.User">  
  7.         <id name="id">  
  8.             <generator class="uuid"/>  
  9.         </id>  
  10.         <property name="name"/>  
  11.         <property name="password"/>  
  12.         <property name="createTime"/>  
  13.         <property name="expireTime"/>  
  14.     </class>  
  15. </hibernate-mapping> 

6.我們也映射完畢了,但是hibernate怎么知道我們映射完了呢,以及如何映射的呢?這就需要我們把我們自己的映射文件告訴hibernate,即:在hibernate.cfg.xml配置我們的映射文件。

  1. <mapping resource="com/bjpowernode/hibernate/User.hbm.xml"/> 

7.生成數據庫表。大家也看到了我們上述還沒有新建數據表呢,在第三步我們只是新建了數據庫而已。按照我們普通的做法,我們應該新建數據表啊,否則實體存放何處啊。這個別急,數據庫表這個肯定是需要有的,這個毋庸置疑,但是這個可不像我們原來需要自己親自動手建立哦,現在hibernate需要幫我們實現哦,如何實現嗯,hibernate會根據配置文件hibernate.cfg.xml和我們的映射文件User.hbm.xml會自動給我們生成相應的表,并且這個表的名字也給我們取好:默認是User。那如何生成表呢?

  1. //默認讀取hibernate.cfg.xml文件  
  2.     Configuration cfg = new Configuration().configure();  
  3.       
  4.     SchemaExport export = new SchemaExport(cfg);  
  5.     export.create(truetrue); 

 8.那我們就開始進行操作啦,我們添加一個用戶對象,看看hibernate是如何添加的呢?跟我們以前的做法有什么不同呢?

  1. public class Client {  
  2.  
  3.     public static void main(String[] args) {  
  4.           
  5.         //讀取hibernate.cfg.xml文件  
  6.         Configuration cfg = new Configuration().configure();  
  7.           
  8.         //建立SessionFactory  
  9.         SessionFactory factory = cfg.buildSessionFactory();  
  10.           
  11.         //取得session  
  12.         Session session = null;  
  13.         try {  
  14.             session = factory.openSession();  
  15.             //開啟事務  
  16.             session.beginTransaction();  
  17.             User user = new User();  
  18.             user.setName("張三");  
  19.             user.setPassword("123");  
  20.             user.setCreateTime(new Date());  
  21.             user.setExpireTime(new Date());  
  22.               
  23.             //保存User對象  
  24.             session.save(user);  
  25.               
  26.             //提交事務  
  27.             session.getTransaction().commit();  
  28.         }catch(Exception e) {  
  29.             e.printStackTrace();  
  30.             //回滾事務  
  31.             session.getTransaction().rollback();  
  32.         }finally {  
  33.             if (session != null) {  
  34.                 if (session.isOpen()) {  
  35.                     //關閉session  
  36.                     session.close();  
  37.                 }  
  38.             }  
  39.         }  
  40.     }  

第八步,我們可以看到,沒有我們熟悉的insert into表的sql語句了,那怎么添加進去的呢,到底添加了沒?讓我真實滴告訴你,確實添加進去了,不信的,可以自己嘗試哦,這也是hibernate的優點,對jdbc封裝的徹底,減少了我們對數據的操作時間哈。

這篇博客就是真切滴介紹了hibernate的基本用法,其中好多優點等待我們自己去發現哦,比如hibernate中的緩存機制,映射方案哦。

 

原文鏈接:http://blog.csdn.net/llhhyy1989/article/details/7299619

【編輯推薦】

  1. 為什么用Spring來管理Hibernate?
  2. Java并行編程:從并行任務集獲取反饋
  3. Java反射機制初探
  4. 不再糾結Java中的String類
  5. Java中常見IO的讀寫效率對比
責任編輯:林師授 來源: llhhyy1989的博客
相關推薦

2023-09-26 01:03:36

Pandas數據數據集

2010-10-22 11:31:53

SQL Server自

2010-08-29 20:56:02

路由器DHCP配置

2009-08-26 16:56:49

Oracle訪問Syb

2009-10-21 15:03:50

VB入門教程

2015-04-09 14:58:45

OpenStackDocker私有云搭建

2010-06-02 18:38:08

搭建SVN服務器

2023-05-19 15:51:36

數據治理工具

2010-04-09 11:21:37

Linux下配置VSf

2010-07-02 14:26:55

Visio畫UML用例

2017-09-20 07:09:23

網線雙絞線電纜

2009-02-24 09:56:41

DBA職業生涯求職

2011-04-25 09:24:50

打印機

2011-07-12 22:21:35

打印機技巧

2011-04-28 10:20:22

打印機

2009-02-24 20:45:53

軟考信息系統集成項目管理工作

2014-09-18 09:42:15

2018-04-23 14:23:12

2009-09-23 16:30:01

Hibernate f

2009-09-21 17:33:50

Hibernate基礎
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品久久久久久久三级 | 日韩精品一区二区三区在线播放 | 一区二区免费 | 欧洲视频一区 | 精品蜜桃一区二区三区 | 国产香蕉视频 | 狠狠av | 亚州av在线 | 一区视频在线免费观看 | 日本粉嫩一区二区三区视频 | 欧美成人精品一区二区男人看 | 亚洲黄色网址视频 | 国产一区欧美一区 | 黑人巨大精品欧美一区二区一视频 | 日韩精品久久久久 | 国产毛片久久久 | 99精品一级欧美片免费播放 | 成人免费视屏 | 中文字幕高清视频 | 国产精品国产精品国产专区不蜜 | 九九热在线免费视频 | 国产免费一区 | 欧美在线视频a | 殴美成人在线视频 | 久久精片| 国产91久久久久蜜臀青青天草二 | 久久亚洲一区二区 | 亚洲成人免费av | 古装人性做爰av网站 | 在线a视频网站 | 91精品国产综合久久久动漫日韩 | 欧美日韩综合精品 | 欧美成人aaa级毛片在线视频 | 日日天天 | 欧美黄色网 | 亚洲一区av| 日韩在线视频一区二区三区 | 欧美a级成人淫片免费看 | 亚洲欧美日韩电影 | 久久婷婷麻豆国产91天堂 | 亚洲国产精品人人爽夜夜爽 |