Hibernate單表操作實(shí)例解析
單一主鍵
assigned:由Java應(yīng)用程序負(fù)責(zé)生成(即手工的賦值)
native:由底層的數(shù)據(jù)庫(kù)自動(dòng)的生成標(biāo)示符,如果是MySQL就是auto_increment,如果是Oracle就是sequence,等等
操作的時(shí)候還是需要結(jié)合hibernate.cfg.xml文件的,因?yàn)閿?shù)據(jù)庫(kù)中的hbm2ddl.auto屬性如果是update的時(shí)候,設(shè)置為主鍵自增是可以的;但是如果是create的時(shí)候,第二次如果不手工的改變,恐怕就要出BUG了。
基本類(lèi)型
一般來(lái)說(shuō),按照J(rèn)ava的數(shù)據(jù)類(lèi)型進(jìn)行操作就可以。
其中最容易出錯(cuò)的數(shù)據(jù)類(lèi)型是date 和 timestamp兩種。
- date類(lèi)型既可以映射成java.util.Date,也可以映射成java.sql.Date類(lèi)型。代表日期:yyyy-MM-dd
- time類(lèi)型映射成java.util.Time 和java.sql.Time代表的時(shí)間:hh:mm:ss
- timesaamp可以映射成java.util.Date或者java.sql.TimeStamp類(lèi)型,代表的時(shí)間和日期:yyyymmddhhmmss
如何更改其阿紫數(shù)據(jù)庫(kù)中的數(shù)據(jù)庫(kù)類(lèi)型呢?
在XX.hbm.xml文件中對(duì)class對(duì)象的property的type屬性進(jìn)行更改即可。改成Hibernate自帶的數(shù)據(jù)類(lèi)型就可以了。
對(duì)象類(lèi)型
下面是Hibernate支持的對(duì)象類(lèi)型的總結(jié):
操作的時(shí)候只需要按照相應(yīng)的API即可。
需要注意的是MySQL不支持標(biāo)準(zhǔn)的CLOB類(lèi)型,在MySQL中用TEXT,MEDIUMTEXT及LONGTEXT類(lèi)型來(lái)表示長(zhǎng)度超過(guò)255的長(zhǎng)文本數(shù)據(jù)。
組件屬性
實(shí)體類(lèi)中某個(gè)屬性屬于用戶(hù)自定義的類(lèi)的對(duì)象
如:
<component name="address" class="Address"> <property name="postcode" column="POSTCODE" /> <property name="phone" column="PHONE" /> <property name="address" column="ADDRESS" /> </component>
也就是說(shuō)一旦是用戶(hù)自定義的類(lèi)型的話,在XX.hbm.xml文件中就要使用component標(biāo)簽,而不是單純的property標(biāo)簽了。這一點(diǎn)應(yīng)該有其的注意。
單表操作CRUD的實(shí)例
這里主要是使用到了session的幾個(gè)常用的api。如save,update,delete,和get/load等等。
- save:直接調(diào)用session.save(對(duì)象的實(shí)例)
- get/load:session.get/load(XX.class,標(biāo)示符);其中這個(gè)標(biāo)示符可以是主鍵對(duì)應(yīng)的值
- update:session.update(對(duì)象的實(shí)例)
- delete:session.delete(對(duì)象的實(shí)例)
get與load的區(qū)別:
- 一、不考慮緩存的情況下,get方法在調(diào)用之后立即的向數(shù)據(jù)庫(kù)發(fā)送SQL語(yǔ)句,返回持久化的對(duì)象,而load方法會(huì)在調(diào)用后返回一個(gè)代理的對(duì)象,該代理對(duì)象只保存了實(shí)體對(duì)象的id,知道適用對(duì)象的非主鍵屬性時(shí)才會(huì)發(fā)出sql語(yǔ)句。
- 二、查詢(xún)數(shù)據(jù)庫(kù)中不存在的數(shù)據(jù)時(shí),get方法返回的是null,load方法則會(huì)拋出異常org.hibernate.ObjectNotFoundException
總結(jié)
以上就是本文關(guān)于Hibernate單表操作實(shí)例解析的全部?jī)?nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專(zhuān)題,如有不足之處,歡迎留言指出。感謝朋友們對(duì)本站的支持!
- Hibernate中Session增刪改查操作代碼詳解
- hibernate通過(guò)session實(shí)現(xiàn)增刪改查操作實(shí)例解析
- hibernate增刪改查操作代碼
- Hibernate對(duì)數(shù)據(jù)庫(kù)刪除、查找、更新操作實(shí)例代碼
- 全面解析Hibernate關(guān)聯(lián)操作、查詢(xún)操作、高級(jí)特性、并發(fā)處理機(jī)制
- hibernate批量操作實(shí)例詳解
- Java的Hibernate框架數(shù)據(jù)庫(kù)操作中鎖的使用和查詢(xún)類(lèi)型
- Java的Hibernate框架中用于操作數(shù)據(jù)庫(kù)的HQL語(yǔ)句講解
相關(guān)文章
Java 1.0和Java 1.1 的IO類(lèi)的比較
Java庫(kù)的IO分為輸入/輸出兩部分。早期的Java 1.0版本的輸入系統(tǒng)是InputStream及其子類(lèi),輸出系統(tǒng)是OutputStream及其子類(lèi)。后來(lái)的Java 1.1版本對(duì)IO系統(tǒng)進(jìn)行了重新設(shè)計(jì)。本分對(duì)此做了分析和比較,有利于學(xué)習(xí),最后給出了例子。2013-11-11實(shí)現(xiàn)quartz定時(shí)器及quartz定時(shí)器原理介紹
Quartz是一個(gè)大名鼎鼎的Java版開(kāi)源定時(shí)調(diào)度器,功能強(qiáng)悍,使用方便,下面我們看看如何使用它2013-12-12Mybatis基于注解形式的sql語(yǔ)句生成實(shí)例代碼
這篇文章主要介紹了 Mybatis基于注解形式的sql語(yǔ)句生成實(shí)例代碼,需要的朋友可以參考下2017-09-09java swing實(shí)現(xiàn)簡(jiǎn)單的五子棋游戲
這篇文章主要為大家詳細(xì)介紹了java swing實(shí)現(xiàn)簡(jiǎn)單的五子棋游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-03-03SpringBoot實(shí)現(xiàn)緩存預(yù)熱的幾種常用方案
緩存預(yù)熱是指在 Spring Boot 項(xiàng)目啟動(dòng)時(shí),預(yù)先將數(shù)據(jù)加載到緩存系統(tǒng)(如 Redis)中的一種機(jī)制,本文給大家介紹了SpringBoot實(shí)現(xiàn)緩存預(yù)熱的幾種常用方案,并通過(guò)代碼示例講解的非常詳細(xì),需要的朋友可以參考下2024-02-02SpringBoot實(shí)現(xiàn)阿里云快遞物流查詢(xún)的示例代碼
本文將基于springboot實(shí)現(xiàn)快遞物流查詢(xún),物流信息的獲取通過(guò)阿里云第三方實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2021-10-10