eric-1001c

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

          1.內置映射類型
             1).Java基本類型的Hibernate映射類型
          Java類型 Hibernate映射類型 標準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映射類型 標準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

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

              3). Java 大對象類型的Hibernate映射類型
          Java類型 Hibernate映射類型 標準SQL類型 MySql類型 Oracle類型
          byte[] binary VARBINARY/BLOB BLOB BLOB
          String text CLOB TEXT CLOB
          serializable 實現serializable接口的一個java類 VARBINARY/BLOB BLOB BLOB
          java.sql.Clob clob CLOB TEXT CLOB
          java.sql.Blob blob BLOB BLOB BLOB
          *  在應用程序中通過Hibernate來保存java.sql.Clob或者java.sql.Blob實例時,必須包含兩個步驟:
                  a. 在一個數據庫事務中先保存一個空的Blob或Clob實例;b. 接著鎖定這條記錄,更新在步驟(1)中保存的Blob或Clob實例,把二進制數據或長文本數據寫到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類型對應多個Hibernate映射類型的場合。例如,如果持久化類的屬性為java.util.Date類型,對應的Hibernate映射類型可以是date,time
          或timestamp。此時必須根據對應的數據庫表的字段的SQL類型,來確定Hibernate映射類型。如果字段為Date類型,則hibernate映射為datge,如果為TIME則為time,如果為TIMESTAMP則為timestamp。


          2.客戶化映射類型
               (很麻煩的一個東西,稍微看了看,日后需要再研究并總結)
          posted on 2008-01-24 15:57 Eric-1001c 閱讀(3413) 評論(0)  編輯  收藏 所屬分類: Hibernate
          主站蜘蛛池模板: 嘉定区| 洛宁县| 克拉玛依市| 漠河县| 万年县| 长岛县| 都兰县| 镇宁| 鹤庆县| 子洲县| 都匀市| 确山县| 开化县| 河津市| 竹北市| 金门县| 凉山| 长兴县| 无极县| 泉州市| 蓝田县| 三都| 永泰县| 会同县| 康定县| 孟连| 屯留县| 旌德县| 饶平县| 安顺市| 比如县| 潼南县| 礼泉县| 子洲县| 噶尔县| 永兴县| 沈丘县| 铁岭县| 中卫市| 古蔺县| 郎溪县|