我的Blog我做主^_^

          走向一條通往JAVA的不歸路...

            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
            64 隨筆 :: 68 文章 :: 77 評論 :: 0 Trackbacks
           

          借助于Hibernate強大的O/R Mapping能力,我們能夠通過discriminator輕易地將一顆繼承樹映射到一個表中,通過discriminator確定具體映射的子類。

           

          在設置@hibernate.discriminator column="type" type="integer"后,啟動Hibernate報錯:

          Could not format discriminator value to SQL string

           http://dev.csdn.net/article/82/82734.shtm

          http://forum.hibernate.org/viewtopic.php?t=974225

          搜索Hibernate官方文檔后發現問題,原來Hibernate默認的discriminatortypeString,當設置discriminatortypeinteger后,需要為父類也設置@hibernate.class table="TABLE_NAME" discriminator-value="not null",否則,Hibernate默認的discriminator-value是完整的類名,在轉換Stringint時造成NumberFormatException

           

          最后運行XDoclet,生成hbm文件:

           

          <?xml version="1.0" encoding="iso-8859-1"?>

          <!DOCTYPE hibernate-mapping PUBLIC

              "-//Hibernate/Hibernate Mapping DTD 3.0//EN"

              "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

          <hibernate-mapping>

              <class name="com.crackj2ee.example.AbstractClass" table="TABLE_NAME" discriminator-value="not null">

                  <id name="id" column="id" type="java.lang.Long" unsaved-value="null">

                      <generator class="increment"/>

                  </id>

                  <discriminator column="type" not-null="true" type="integer"/>

                  <subclass name="com.crackj2ee.example.SubClass1" discriminator-value="1">

                  <subclass name="com.crackj2ee.example.SubClass2" discriminator-value="2">

              </class>

          </hibernate-mapping>



          posted on 2008-10-22 10:48 java_蟈蟈 閱讀(1060) 評論(0)  編輯  收藏 所屬分類: HIBERNATE
          主站蜘蛛池模板: 甘谷县| 阿尔山市| 兰溪市| 鹰潭市| 桃园县| 洛阳市| 邹平县| 永城市| 阿鲁科尔沁旗| 泗水县| 拜泉县| 鄂尔多斯市| 溧阳市| 玉溪市| 阳谷县| 岳普湖县| 吉隆县| 扬中市| 贡山| 新丰县| 尚义县| 松溪县| 偃师市| 阿坝县| 米泉市| 万全县| 昌图县| 嘉荫县| 英山县| 民县| 周口市| 长岛县| 泰安市| 四会市| 图们市| 西乌珠穆沁旗| 林甸县| 阿拉尔市| 中江县| 高唐县| 沿河|