eric-1001c

            BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
            3 隨筆 :: 45 文章 :: 12 評論 :: 0 Trackbacks
              Hibernate映射類型分為兩種:內(nèi)置的映射類型和客戶化映射類型。內(nèi)置映射類型負(fù)責(zé)把一些常見的Java類型映射到相應(yīng)的SQL類型;此外,Hibernate還允許用戶實現(xiàn)UserType或CompositeUserType接口,來靈活地定制客戶化映射類型

          1.內(nèi)置映射類型
             1).Java基本類型的Hibernate映射類型
          Java類型 Hibernate映射類型 標(biāo)準(zhǔn)SQL類型 大小和取值范圍
          int/Integer int/integer INTEGER 4Byte
          long/Long    long BIGINT 8Byte
          short/Short short SAMLLINT 2Byte
          byte/Byte byte TINYINT 1Byte
          float/Float float FLOAT 4Byte
          double/Double double DOUBLE 8Byte
          BigDecimal big_decimal NUMBERIC Numeric(8,2)
          char/Character/String character CHAR(1) 定長字符
          String string VARCHAR 變長字符
          boolean/Boolean boolean BIT 布爾類型
          boolean/Boolean yes/no CHAR(1)('Y'/'N') 布爾類型
          boolean/Boolean true/false CHAR(1)('T'/'F') 布爾類型


              2). Java時間和日期類型的Hibernate映射類型
          Java類型 Hibernate映射類型 標(biāo)準(zhǔn)SQL類型 描述
          java.util.Date/java.sql.Date date DATE 日期,yyyy-mm-dd
          java.util.Date/java.sql.TIme time TIME 時間,hh:mm:ss
          java.util.Date/java.sql.Timestamp timestamp TIMESTAMP 時間戳,yyyymmddhhmmss
          java.util.Calendar calendar TIMESTAMP 同上
          java.util.Calendar calendar_date DATE 日期,yyyy-mm-dd

          * 當(dāng)程序類型為java.sql.Timestamp, 數(shù)據(jù)庫中表屬性類型為timestamp的情況下,即使用戶以空值插入數(shù)據(jù),數(shù)據(jù)庫系統(tǒng)仍然會自動填充timestamp的值

              3). Java 大對象類型的Hibernate映射類型
          Java類型 Hibernate映射類型 標(biāo)準(zhǔn)SQL類型 MySql類型 Oracle類型
          byte[] binary VARBINARY/BLOB BLOB BLOB
          String text CLOB TEXT CLOB
          serializable 實現(xiàn)serializable接口的一個java類 VARBINARY/BLOB BLOB BLOB
          java.sql.Clob clob CLOB TEXT CLOB
          java.sql.Blob blob BLOB BLOB BLOB
          *  在應(yīng)用程序中通過Hibernate來保存java.sql.Clob或者java.sql.Blob實例時,必須包含兩個步驟:
                  a. 在一個數(shù)據(jù)庫事務(wù)中先保存一個空的Blob或Clob實例;b. 接著鎖定這條記錄,更新在步驟(1)中保存的Blob或Clob實例,把二進制數(shù)據(jù)或長文本數(shù)據(jù)寫到Blob或Clob實例中。
           1
           2Session session = sessionFactory.openSession();
           3Transaction tx = session.beginTransaction();
           4Customer customer = new Customer();
           5customer.setDescription(Hibernate.createClob("")); //先保存一個空的clob
           6session.save(customer);
           7session.flush();
           8//鎖定這條記錄
           9session.refresh(customer,LockMode.UPGRADE);
          10oracle.sql.CLOB clob = (oracle.sql.CLOB) customer.getDescription();
          11java.io.Writer pw = clob.getCharacterOutStream();
          12pw.write(longText);//longText是一個長度超過255的字符串
          13pw.close();
          14tx.commit();
          15session.close();

          *  一個java類型對應(yīng)多個Hibernate映射類型的場合。例如,如果持久化類的屬性為java.util.Date類型,對應(yīng)的Hibernate映射類型可以是date,time
          或timestamp。此時必須根據(jù)對應(yīng)的數(shù)據(jù)庫表的字段的SQL類型,來確定Hibernate映射類型。如果字段為Date類型,則hibernate映射為datge,如果為TIME則為time,如果為TIMESTAMP則為timestamp。


          2.客戶化映射類型
               (很麻煩的一個東西,稍微看了看,日后需要再研究并總結(jié))
          posted on 2008-01-24 15:57 Eric-1001c 閱讀(3417) 評論(0)  編輯  收藏 所屬分類: Hibernate
          主站蜘蛛池模板: 宁津县| 广灵县| 莱西市| 罗城| 武强县| 郓城县| 石柱| 嘉兴市| 新宁县| 宁城县| 明溪县| 师宗县| 太原市| 长宁区| 古田县| 邛崃市| 甘德县| 玛曲县| 延长县| 蓝田县| 遵义县| 高州市| 大渡口区| 德庆县| 化德县| 湟中县| 保靖县| 辽阳县| 天全县| 余干县| 曲阳县| 奉节县| 容城县| 咸丰县| 和平区| 巴彦县| 资溪县| 阳新县| 重庆市| 和田县| 神木县|