我的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_蟈蟈 閱讀(1059) 評論(0)  編輯  收藏 所屬分類: HIBERNATE
          主站蜘蛛池模板: 潞城市| 白水县| 页游| 上蔡县| 闵行区| 江都市| 明水县| 阿拉善左旗| 仪陇县| 临沧市| 彭州市| 四川省| 茶陵县| 忻州市| 广西| 成武县| 鹿泉市| 临朐县| 隆尧县| 昆山市| 万山特区| 信丰县| 色达县| 麦盖提县| 绍兴县| 莱阳市| 民县| 邛崃市| 墨竹工卡县| 扎鲁特旗| 江永县| 恩平市| 监利县| 安吉县| 辉南县| 志丹县| 宜都市| 铁岭市| 万源市| 连江县| 五原县|