assigned:由Java應用程序負責生成(即手工的賦值)
native:由底層的數據庫自動的生成標示符,如果是MySQL就是auto_increment,如果是Oracle就是sequence,等等
操作的時候還是需要結合hibernate.cfg.xml文件的,因為數據庫中的hbm2ddl.auto屬性如果是update的時候,設置為主鍵自增是可以的;但是如果是create的時候,第二次如果不手工的改變,恐怕就要出BUG了。
一般來說,按照Java的數據類型進行操作就可以。
其中最容易出錯的數據類型是date 和timestamp兩種。
- date類型既可以映射成java.util.Date,也可以映射成java.sql.Date類型。代表日期:yyyy-MM-dd
- time類型映射成java.util.Time 和java.sql.Time代表的時間:hh:mm:ss
- timesaamp可以映射成java.util.Date或者java.sql.TimeStamp類型,代表的時間和日期:yyyymmddhhmmss
如何更改其阿紫數據庫中的數據庫類型呢?
在XX.hbm.xml文件中對class對象的property的type屬性進行更改即可。改成Hibernate自帶的數據類型就可以了。
下面是Hibernate支持的對像類型的總結:
操作的時候只需要按照相應的API即可。
需要注意的是MySQL不支持標準的CLOB類型,在MySQL中用TEXT,MEDIUMTEXT及LONGTEXT類型來表示長度超過255的長文本數據。
實體類中某個屬性屬於用戶自定義的類的對象
如:
<component name="address"> <property name="postcode" column="POSTCODE" /> <property name="phone" column="PHONE" /> <property name="address" column="ADDRESS" /></component>
也就是說一旦是用戶自定義的類型的話,在XX.hbm.xml文件中就要使用component標籤,而不是單純的property標籤了。這一點應該有其的注意。
這裡主要是使用到了session的幾個常用的api。如save,update,delete,和get/load等等。
- save:直接調用session.save(對象的實例)
- get/load:session.get/load(XX.class,標示符);其中這個標示符可以是主鍵對應的值
- update:session.update(對象的實例)
- delete:session.delete(對象的實例)
- 一、不考慮緩存的情況下,get方法在調用之後立即的向數據庫發送SQL語句,返回持久化的對象,而load方法會在調用後返回一個代理的對象,該代理對像只保存了實體對象的id,知道適用對象的非主鍵屬性時才會發出sql語句。
- 二、查詢數據庫中不存在的數據時,get方法返回的是null,load方法則會拋出異常org.hibernate.ObjectNotFoundException
以上就是本文關於Hibernate單表操作實例解析的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續參閱本站其他相關專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!