﻿<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:trackback="http://madskills.com/public/xml/rss/module/trackback/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:slash="http://purl.org/rss/1.0/modules/slash/"><channel><title>BlogJava-feifeirao-文章分类-Hibernate</title><link>http://www.blogjava.net/feifeirao/category/22852.html</link><description /><language>zh-cn</language><lastBuildDate>Fri, 11 May 2012 16:13:45 GMT</lastBuildDate><pubDate>Fri, 11 May 2012 16:13:45 GMT</pubDate><ttl>60</ttl><item><title>使用SQLQuery http://blog.sina.com.cn/s/blog_53a73e790100ll6v.html</title><link>http://www.blogjava.net/feifeirao/articles/377386.html</link><dc:creator>五味子</dc:creator><author>五味子</author><pubDate>Fri, 04 May 2012 07:35:00 GMT</pubDate><guid>http://www.blogjava.net/feifeirao/articles/377386.html</guid><wfw:comment>http://www.blogjava.net/feifeirao/comments/377386.html</wfw:comment><comments>http://www.blogjava.net/feifeirao/articles/377386.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/feifeirao/comments/commentRss/377386.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/feifeirao/services/trackbacks/377386.html</trackback:ping><description><![CDATA[使用SQLQuery (2010-09-27 09:29:23)转载▼
分类： J2EE

对原生SQL查询执行的控制是通过SQLQuery接口进行的，通过执行Session.createSQLQuery()获取这个接口。下面来描述如何使用这个API进行查询。
标量查询（Scalar queries）
最基本的SQL查询就是获得一个标量（数值）的列表。
sess.createSQLQuery("SELECT * FROM CATS").list(); sess.createSQLQuery("SELECT ID, NAME, BIRTHDATE FROM CATS").list();
它们都将返回一个Object数组(Object[])组成的List，数组每个元素都是CATS表的一个字段值。Hibernate会使用ResultSetMetadata来判定返回的标量值的实际顺序和类型。
如果要避免过多的使用ResultSetMetadata,或者只是为了更加明确的指名返回值，可以使用addScalar()。
sess.createSQLQuery("SELECT * FROM CATS") .addScalar("ID", Hibernate.LONG) .addScalar("NAME", Hibernate.STRING) .addScalar("BIRTHDATE", Hibernate.DATE)
这个查询指定了:
SQL查询字符串
要返回的字段和类型
它仍然会返回Object数组,但是此时不再使用ResultSetMetdata,而是明确的将ID,NAME和BIRTHDATE按照Long,String和Short类型从resultset中取出。同时，也指明了就算query是使用*来查询的，可能获得超过列出的这三个字段，也仅仅会返回这三个字段。
对全部或者部分的标量值不设置类型信息也是可以的。
sess.createSQLQuery("SELECT * FROM CATS") .addScalar("ID", Hibernate.LONG) .addScalar("NAME") .addScalar("BIRTHDATE")
基本上这和前面一个查询相同,只是此时使用ResultSetMetaData来决定NAME和BIRTHDATE的类型，而ID的类型是明确指出的。
关于从ResultSetMetaData返回的java.sql.Types是如何映射到Hibernate类型，是由方言(Dialect)控制的。假若某个指定的类型没有被映射，或者不是你所预期的类型，你可以通过Dialet的registerHibernateType调用自行定义。
16.1.2. 实体查询(Entity queries)
上面的查询都是返回标量值的，也就是从resultset中返回的“裸”数据。下面展示如何通过addEntity()让原生查询返回实体对象。
sess.createSQLQuery("SELECT * FROM CATS").addEntity(Cat.class); sess.createSQLQuery("SELECT ID, NAME, BIRTHDATE FROM CATS").addEntity(Cat.class);
这个查询指定：
SQL查询字符串
要返回的实体
假设Cat被映射为拥有ID,NAME和BIRTHDATE三个字段的类，以上的两个查询都返回一个List，每个元素都是一个Cat实体。
假若实体在映射时有一个many-to-one的关联指向另外一个实体，在查询时必须也返回那个实体，否则会导致发生一个"column not found"的数据库错误。这些附加的字段可以使用*标注来自动返回，但我们希望还是明确指明，看下面这个具有指向Dog的many-to-one的例子：
sess.createSQLQuery("SELECT ID, NAME, BIRTHDATE, DOG_ID FROM CATS").addEntity(Cat.class);
这样cat.getDog()就能正常运作。
16.1.3. 处理关联和集合类(Handling associations and collections)
通过提前抓取将Dog连接获得，而避免初始化proxy带来的额外开销也是可能的。这是通过addJoin()方法进行的，这个方法可以让你将关联或集合连接进来。
sess.createSQLQuery("SELECT c.ID, NAME, BIRTHDATE, DOG_ID, D_ID, D_NAME FROM CATS c, DOGS d WHERE c.DOG_ID = d.D_ID") .addEntity("cat", Cat.class) .addJoin("cat.dog");
上面这个例子中，返回的Cat对象，其dog属性被完全初始化了，不再需要数据库的额外操作。注意，我们加了一个别名("cat")，以便指明join的目标属性路径。通过同样的提前连接也可以作用于集合类，例如，假若Cat有一个指向Dog的一对多关联。
sess.createSQLQuery("SELECT ID, NAME, BIRTHDATE, D_ID, D_NAME, CAT_ID FROM CATS c, DOGS d WHERE c.ID = d.CAT_ID") .addEntity("cat", Cat.class) .addJoin("cat.dogs");
<p> 到此为止，我们碰到了天花板：若不对SQL查询进行增强，这些已经是在Hibernate中使用原生SQL查询所能做到的最大可能了。下面的问题即将出现：返回多个同样类型的实体怎么办？或者默认的别名/字段不够又怎么办？ </p>
16.1.4. 返回多个实体(Returning multiple entities)
到目前为止,结果集字段名被假定为和映射文件中指定的的字段名是一致的。假若SQL查询连接了多个表，同一个字段名可能在多个表中出现多次，这就会造成问题。
下面的查询中需要使用字段别名注射（这个例子本身会失败）：
sess.createSQLQuery("SELECT c.*, m.* FROM CATS c, CATS m WHERE c.MOTHER_ID = c.ID") .addEntity("cat", Cat.class) .addEntity("mother", Cat.class)
这个查询的本意是希望每行返回两个Cat实例，一个是cat,另一个是它的妈妈。但是因为它们的字段名被映射为相同的，而且在某些数据库中，返回的字段别名是“c.ID”,"c.NAME"这样的形式，而它们和在映射文件中的名字（"ID"和"NAME"）不匹配，这就会造成失败。
下面的形式可以解决字段名重复：
sess.createSQLQuery("SELECT {cat.*}, {mother.*} FROM CATS c, CATS m WHERE c.MOTHER_ID = c.ID") .addEntity("cat", Cat.class) .addEntity("mother", Cat.class)
这个查询指明：
SQL查询语句，其中包含占位附来让Hibernate注射字段别名
查询返回的实体
上面使用的{cat.*}和{mother.*}标记是作为“所有属性”的简写形式出现的。当然你也可以明确地罗列出字段名，但在这个例子里面我们让Hibernate来为每个属性注射SQL字段别名。字段别名的占位符是属性名加上表别名的前缀。在下面的例子中，我们从另外一个表（cat_log）中通过映射元数据中的指定获取Cat和它的妈妈。注意，要是我们愿意，我们甚至可以在where子句中使用属性别名。
String sql = "SELECT ID as {c.id}, NAME as {c.name}, " + "BIRTHDATE as {c.birthDate}, MOTHER_ID as {c.mother}, {mother.*} " + "FROM CAT_LOG c, CAT_LOG m WHERE {c.mother} = c.ID"; List loggedCats = sess.createSQLQuery(sql) .addEntity("cat", Cat.class) .addEntity("mother", Cat.class).list()
16.1.4.1. 别名和属性引用(Alias and property references)
大多数情况下，都需要上面的属性注射，但在使用更加复杂的映射，比如复合属性、通过标识符构造继承树，以及集合类等等情况下，也有一些特别的别名，来允许Hibernate注射合适的别名。
下表列出了使用别名注射参数的不同可能性。注意：下面结果中的别名只是示例，实用时每个别名需要唯一并且不同的名字。
表 16.1. 别名注射(alias injection names)
描述	语法	示例
简单属性	{[aliasname].[propertyname]	A_NAME as {item.name}
复合属性	{[aliasname].[componentname].[propertyname]}	CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}
实体辨别器(Discriminator of an entity)	{[aliasname].class}	DISC as {item.class}
实体的所有属性	{[aliasname].*}	{item.*}
集合键(collection key)	{[aliasname].key}	ORGID as {coll.key}
集合id	{[aliasname].id}	EMPID as {coll.id}
集合元素	{[aliasname].element}	XID as {coll.element}	
集合元素的属性	{[aliasname].element.[propertyname]}	NAME as {coll.element.name}	
集合元素的所有属性	{[aliasname].element.*}	{coll.element.*}	
集合的所有属性	{[aliasname].*}	{coll.*}	
16.1.5. 返回非受管实体(Returning non-managed entities)
可以对原生sql 查询使用ResultTransformer。这会返回不受Hibernate管理的实体。
sess.createSQLQuery("SELECT NAME, BIRTHDATE FROM CATS") .setResultTransformer(Transformers.aliasToBean(CatDTO.class))
这个查询指定：
SQL查询字符串
结果转换器(result transformer)
上面的查询将会返回CatDTO的列表,它将被实例化并且将NAME和BIRTHDAY的值注射入对应的属性或者字段。
16.1.6. 处理继承（Handling inheritance）
原生SQL查询假若其查询结果实体是继承树中的一部分，它必须包含基类和所有子类的所有属性。
16.1.7. 参数（Parameters）
原生查询支持位置参数和命名参数：
Query query = sess.createSQLQuery("SELECT * FROM CATS WHERE NAME like ?").addEntity(Cat.class); List pusList = query.setString(0, "Pus%").list(); query = sess.createSQLQuery("SELECT * FROM CATS WHERE NAME like :name").addEntity(Cat.class); List pusList = query.setString("name", "Pus%").list();
16.2. 命名SQL查询
可以在映射文档中定义查询的名字,然后就可以象调用一个命名的HQL查询一样直接调用命名SQL查询.在这种情况下,我们addEntity()方法.
<sql-query > <return alias="person" class="eg.Person"/> SELECT person.NAME AS {person.name}, person.AGE AS {person.age}, person.SEX AS {person.sex} FROM PERSON person WHERE person.NAME LIKE :namePattern </sql-query>
List people = sess.getNamedQuery("persons") .setString("namePattern", namePattern) .setMaxResults(50) .list();
<return-join>和 <load-collection> 元素是用来连接关联以及将查询定义为预先初始化各个集合的。
<sql-query > <return alias="person" class="eg.Person"/> <return-join alias="address" property="person.mailingAddress"/> SELECT person.NAME AS {person.name}, person.AGE AS {person.age}, person.SEX AS {person.sex}, adddress.STREET AS {address.street}, adddress.CITY AS {address.city}, adddress.STATE AS {address.state}, adddress.ZIP AS {address.zip} FROM PERSON person JOIN ADDRESS adddress ON person.ID = address.PERSON_ID AND address.TYPE='MAILING' WHERE person.NAME LIKE :namePattern </sql-query>
一个命名查询可能会返回一个标量值.你必须使用<return-scalar>元素来指定字段的别名和 Hibernate类型
<sql-query > <return-scalar column="name" type="string"/> <return-scalar column="age" type="long"/> SELECT p.NAME AS name, p.AGE AS age, FROM PERSON p WHERE p.NAME LIKE 'Hiber%' </sql-query>
你可以把结果集映射的信息放在外部的<resultset>元素中，这样就可以在多个命名查询间，或者通过setResultSetMapping()API来访问。(此处原文即存疑。原文为：You can externalize the resultset mapping informations in a <resultset> element to either reuse them accross several named queries or through the setResultSetMapping() API.)
<resultset > <return alias="person" class="eg.Person"/> <return-join alias="address" property="person.mailingAddress"/> </resultset> <sql-query name="personsWith" resultset-ref="personAddress"> SELECT person.NAME AS {person.name}, person.AGE AS {person.age}, person.SEX AS {person.sex}, adddress.STREET AS {address.street}, adddress.CITY AS {address.city}, adddress.STATE AS {address.state}, adddress.ZIP AS {address.zip} FROM PERSON person JOIN ADDRESS adddress ON person.ID = address.PERSON_ID AND address.TYPE='MAILING' WHERE person.NAME LIKE :namePattern </sql-query>
另外,你可以在java代码中直接使用hbm文件中的结果集定义信息。
List cats = sess.createSQLQuery( "select {cat.*}, {kitten.*} from cats cat, cats kitten where kitten.mother = cat.id" ) .setResultSetMapping("catAndKitten") .list();
16.2.1. 使用return-property来明确地指定字段/别名
使用<return-property>你可以明确的告诉Hibernate使用哪些字段别名,这取代了使用{}-语法 来让Hibernate注入它自己的别名.
<sql-query > <return alias="person" class="eg.Person"> <return-property name="name" column="myName"/> <return-property name="age" column="myAge"/> <return-property name="sex" column="mySex"/> </return> SELECT person.NAME AS myName, person.AGE AS myAge, person.SEX AS mySex, FROM PERSON person WHERE person.NAME LIKE :name </sql-query>
<return-property>也可用于多个字段,它解决了使用{}-语法不能细粒度控制多个字段的限制
<sql-query > <return alias="emp" class="Employment"> <return-property name="salary"> <return-column name="VALUE"/> <return-column name="CURRENCY"/> </return-property> <return-property name="endDate" column="myEndDate"/> </return> SELECT EMPLOYEE AS {emp.employee}, EMPLOYER AS {emp.employer}, STARTDATE AS {emp.startDate}, ENDDATE AS {emp.endDate}, REGIONCODE as {emp.regionCode}, EID AS {emp.id}, VALUE, CURRENCY FROM EMPLOYMENT WHERE EMPLOYER = :id AND ENDDATE IS NULL ORDER BY STARTDATE ASC </sql-query>
注意在这个例子中,我们使用了<return-property>结合{}的注入语法. 允许用户来选择如何引用字段以及属性.
如果你映射一个识别器(discriminator),你必须使用<return-discriminator> 来指定识别器字段
16.2.2. 使用存储过程来查询
Hibernate 3引入了对存储过程查询(stored procedure)和函数(function)的支持.以下的说明中，这二者一般都适用。 存储过程/函数必须返回一个结果集,作为Hibernate能够使用的第一个外部参数. 下面是一个Oracle9和更高版本的存储过程例子.
CREATE OR REPLACE FUNCTION selectAllEmployments RETURN SYS_REFCURSOR AS st_cursor SYS_REFCURSOR; BEGIN OPEN st_cursor FOR SELECT EMPLOYEE, EMPLOYER, STARTDATE, ENDDATE, REGIONCODE, EID, VALUE, CURRENCY FROM EMPLOYMENT; RETURN st_cursor; END;
在Hibernate里要要使用这个查询,你需要通过命名查询来映射它.
<sql-query callable="true"> <return alias="emp" class="Employment"> <return-property name="employee" column="EMPLOYEE"/> <return-property name="employer" column="EMPLOYER"/> <return-property name="startDate" column="STARTDATE"/> <return-property name="endDate" column="ENDDATE"/> <return-property name="regionCode" column="REGIONCODE"/> <return-property name="id" column="EID"/> <return-property name="salary"> <return-column name="VALUE"/> <return-column name="CURRENCY"/> </return-property> </return> { ? = call selectAllEmployments() } </sql-query>
注意存储过程当前仅仅返回标量和实体.现在不支持<return-join>和<load-collection>
16.2.2.1. 使用存储过程的规则和限制
为了在Hibernate中使用存储过程,你必须遵循一些规则.不遵循这些规则的存储过程将不可用.如果你仍然想要使用他们, 你必须通过session.connection()来执行他们.这些规则针对于不同的数据库.因为数据库 提供商有各种不同的存储过程语法和语义.
对存储过程进行的查询无法使用setFirstResult()/setMaxResults()进行分页。
建议采用的调用方式是标准SQL92: { ? = call functionName(<parameters>) } 或者 { ? = call procedureName(<parameters>}.原生调用语法不被支持。
对于Oracle有如下规则:
函数必须返回一个结果集。存储过程的第一个参数必须是OUT，它返回一个结果集。这是通过Oracle 9或10的SYS_REFCURSOR类型来完成的。在Oracle中你需要定义一个REF CURSOR类型，参见Oracle的手册。
对于Sybase或者MS SQL server有如下规则:
存储过程必须返回一个结果集。.注意这些servers可能返回多个结果集以及更新的数目.Hibernate将取出第一条结果集作为它的返回值， 其他将被丢弃。
如果你能够在存储过程里设定SET NOCOUNT ON，这可能会效率更高，但这不是必需的。
16.3. 定制SQL用来create，update和delete
Hibernate3能够使用定制的SQL语句来执行create,update和delete操作。在Hibernate中，持久化的类和集合已经 包含了一套配置期产生的语句(insertsql, deletesql, updatesql等等)，这些映射标记 <sql-insert>, <sql-delete>, and <sql-update>重载了 这些语句。
<class > <id name="id"> <generator class="increment"/> </id> <property name="name" not-null="true"/> <sql-insert>INSERT INTO PERSON (NAME, ID) VALUES ( UPPER(?), ? )</sql-insert> <sql-update>UPDATE PERSON SET NAME=UPPER(?) WHERE ID=?</sql-update> <sql-delete>DELETE FROM PERSON WHERE ID=?</sql-delete> </class>
这些SQL直接在你的数据库里执行，所以你可以自由的使用你喜欢的任意语法。但如果你使用数据库特定的语法， 这当然会降低你映射的可移植性。
如果设定callable，则能够支持存储过程了。
<class > <id name="id"> <generator class="increment"/> </id> <property name="name" not-null="true"/> <sql-insert callable="true">{call createPerson (?, ?)}</sql-insert> <sql-delete callable="true">{? = call deletePerson (?)}</sql-delete> <sql-update callable="true">{? = call updatePerson (?, ?)}</sql-update> </class>
参数的位置顺序是非常重要的，他们必须和Hibernate所期待的顺序相同。
你能够通过设定日志调试级别为org.hiberante.persister.entity,来查看Hibernate所期待的顺序。在这个级别下， Hibernate将会打印出create,update和delete实体的静态SQL。(如果想看到预计的顺序。记得不要将定制SQL包含在映射文件里， 因为他们会重载Hibernate生成的静态SQL。)
在大多数情况下(最好这么做)，存储过程需要返回插入/更新/删除的行数，因为Hibernate对语句的成功执行有些运行时的检查。 Hibernate常会把进行CUD操作的语句的第一个参数注册为一个数值型输出参数。
CREATE OR REPLACE FUNCTION updatePerson (uid IN NUMBER, uname IN VARCHAR2) RETURN NUMBER IS BEGIN update PERSON set NAME = uname, where ID = uid; return SQL%ROWCOUNT; END updatePerson;
16.4. 定制装载SQL
你可能需要声明你自己的SQL(或HQL)来装载实体
<sql-query > <return alias="pers" class="Person" lock-mode="upgrade"/> SELECT NAME AS {pers.name}, ID AS {pers.id} FROM PERSON WHERE ID=? FOR UPDATE </sql-query>
这只是一个前面讨论过的命名查询声明，你可以在类映射里引用这个命名查询。
<class > <id name="id"> <generator class="increment"/> </id> <property name="name" not-null="true"/> <loader query-ref="person"/> </class>
这也可以用于存储过程
你甚至可以定一个用于集合装载的查询:
<set inverse="true"> <key/> <one-to-many class="Employment"/> <loader query-ref="employments"/> </set>
<sql-query > <load-collection alias="emp" role="Person.employments"/> SELECT {emp.*} FROM EMPLOYMENT emp WHERE EMPLOYER = :id ORDER BY STARTDATE ASC, EMPLOYEE ASC </sql-query>
你甚至还可以定义一个实体装载器，它通过连接抓取装载一个集合:
<sql-query > <return alias="pers" class="Person"/> <return-join alias="emp" property="pers.employments"/> SELECT NAME AS {pers.*}, {emp.*} FROM PERSON pers LEFT OUTER JOIN EMPLOYMENT emp ON pers.ID = emp.PERSON_ID WHERE ID=? </sql-query><img src ="http://www.blogjava.net/feifeirao/aggbug/377386.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/feifeirao/" target="_blank">五味子</a> 2012-05-04 15:35 <a href="http://www.blogjava.net/feifeirao/articles/377386.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Hibernate性能测试</title><link>http://www.blogjava.net/feifeirao/articles/120532.html</link><dc:creator>五味子</dc:creator><author>五味子</author><pubDate>Mon, 28 May 2007 09:44:00 GMT</pubDate><guid>http://www.blogjava.net/feifeirao/articles/120532.html</guid><wfw:comment>http://www.blogjava.net/feifeirao/comments/120532.html</wfw:comment><comments>http://www.blogjava.net/feifeirao/articles/120532.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/feifeirao/comments/commentRss/120532.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/feifeirao/services/trackbacks/120532.html</trackback:ping><description><![CDATA[&nbsp;
<h1><a name=_Toc85529054></a><a name=_Toc85196547></a><a name=_Toc53143170><span><span><span><span>1<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><span>测试环境</span></span></span></a></h1>
<p><span><span><span><span><span>l<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><span>操作系统</span><span>Windows XP Professional Pack2 </span></span></span></span></p>
<p><span><span><span><span><span>l<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><span>数据库</span> <span>Oracle - OraDb<st1:chmetcnv w:st="on" TCSC="0" NumberType="1" Negative="False" HasSpace="False" SourceValue="10" UnitName="g">10g</st1:chmetcnv>_home1</span></span></span></span></p>
<p><span><span><span><span><span>l<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><span>内存</span><span>1.21GB</span></span></span></span></p>
<p><span><span><span><span><span>l<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><span>CPU AMD Athlon(tm) 1.15 GHz</span></span></span></span></p>
<p><span><span><span><span><span>l<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><span>编译环境</span><span> eclipse JDK1.5</span></span></span></span></p>
<p><span><span><span><span><span>l<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><span>程序测试运行环境</span><span> spring+hibernate+junit+mock </span></span></span></span><span><span><span><span>；</span><span><br>mock</span></span></span></span><span><span><span><span>提供测试用例的基类，提供</span><span>SPRING</span></span></span></span><span><span><span><span>的</span><span>ConfigurableListableBeanFactory</span></span></span></span><span><span><span><span>，可以从配置文件中得到</span><span>DAO</span></span></span></span><span><span><span><span>对象</span><span>,Dao</span></span></span></span><span><span><span><span>对象调用</span><span>getHibernateTemplate()</span></span></span></span></p>
<h1><span><span><span><span><span>2<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><span>单表测试</span></span></span></span></h1>
<p><span><span><span><span><span>l<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><span>表名：</span><span>employee_role &nbsp;</span></span></span></span><span><span><span><span>共</span><span>9</span></span></span></span><span><span><span><span>个字段，大字符字段为</span><span>blob</span></span></span></span><span><span><span><span>，其它均为字符类型，总记录数</span><span> 109580</span></span></span></span><span><span><span><span>；</span></span></span></span></p>
<p><span><span><span><span><span>l<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><span>大字符字段：共</span><span>670</span></span></span></span><span><span><span><span>个字符</span></span></span></span></p>
<p><span><span><span><span><span>l<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><span>测试结果：</span></span></span></span></p>
<p><span><span><span><span><span>l<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><span>时间是平均值</span></span></span></span></p>
<div align=center>
<table cellSpacing=0 cellPadding=0 border=1>
    <tbody>
        <tr>
            <td vAlign=top width=210>
            <p><span><span><span><span>调用方法</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=116>
            <p><span><span><span><span>返回记录数</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=139>
            <p><span><span><span><span>是否有大字段</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=104>
            <p><span><span><span><span>时间</span></span></span></span></p>
            </td>
            <span><span></span></span>
        </tr>
        <tr>
            <td vAlign=top width=210>
            <p><span><span><span><span>findAll()</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=116>
            <p><span><span><span><span>全部</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=139>
            <p><span><span><span><span>否</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=104>
            <p><span><span><span><span>21.125</span></span></span></span><span><span><span><span>秒</span></span></span></span></p>
            </td>
            <span><span></span></span>
        </tr>
        <tr>
            <td vAlign=top width=210>
            <p><span><span><span><span>findPageByCriteria(dc,20,5478)</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=116>
            <p><span><span><span><span>最后</span><span>20</span></span></span></span><span><span><span><span>条</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=139>
            <p><span><span><span><span>否</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=104>
            <p><span><span><span><span>0.984</span></span></span></span><span><span><span><span>秒</span></span></span></span></p>
            </td>
            <span><span></span></span>
        </tr>
        <tr>
            <td vAlign=top width=210>
            <p><span><span><span><span>findAll()</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=116>
            <p><span><span><span><span>全部</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=139>
            <p><span><span><span><span>有</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=104>
            <p><span><span><span><span>144.516</span></span></span></span><span><span><span><span>秒</span></span></span></span></p>
            </td>
            <span><span></span></span>
        </tr>
        <tr>
            <td vAlign=top width=210>
            <p><span><span><span><span>findPageByCriteria(dc,20,5478)</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=116>
            <p><span><span><span><span>最后</span><span>20</span></span></span></span><span><span><span><span>条</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=139>
            <p><span><span><span><span>有</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=104>
            <p><span><span><span><span>2.328</span></span></span></span><span><span><span><span>秒</span></span></span></span></p>
            </td>
            <span><span></span></span>
        </tr>
    </tbody>
</table>
</div>
<p><span><span><span>&nbsp;</span></span></span></p>
<p><span><span><span>&nbsp;</span></span></span></p>
<h1><span><span><span><span><span>3<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><span>表关联测试</span></span></span></span></h1>
<p><span><span><span><span><span>l<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><span>父</span><span>(</span></span></span></span><span><span><span><span>一</span><span>) </span></span></span></span><span><span><span><span>表名</span><span> employee </span></span></span></span><span><span><span><span>共</span><span>8</span></span></span></span><span><span><span><span>个字段</span><span>, </span></span></span></span><span><span><span><span>没有大字符字段</span> </span></span></span><span><span><span><span>总记录数</span><span>10958</span></span></span></span></p>
<p><span><span><span><span><span>l<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><span>子</span><span>(</span></span></span></span><span><span><span><span>多</span><span>) </span></span></span></span><span><span><span><span>表名</span><span> employee_role</span></span></span></span><span><span><span><span>共</span><span>8</span></span></span></span><span><span><span><span>个字段</span><span>, </span></span></span></span><span><span><span><span>没有大字符字段</span> </span></span></span><span><span><span><span>总记录数</span><span>109580</span></span></span></span></p>
<p><span><span><span><span><span>l<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></span></span><span>时间是平均值</span></span></span></span></p>
<table cellSpacing=0 cellPadding=0 border=1>
    <tbody>
        <tr>
            <td vAlign=top width=114>
            <p><span><span><span><span>调用方法</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>加载对象</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>延迟加载</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>返回记录数</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>时间</span></span></span></span></p>
            </td>
            <span><span></span></span>
        </tr>
        <tr>
            <td vAlign=top width=114>
            <p><span><span><span><span>findAll()</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>子</span><span>(</span></span></span></span><span><span><span><span>多</span><span>)</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>否</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>全部</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>178.89</span></span></span></span><span><span><span><span>秒</span></span></span></span></p>
            </td>
            <span><span></span></span>
        </tr>
        <tr>
            <td vAlign=top width=114>
            <p><span><span><span><span>findAll()</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>父</span><span>(</span></span></span></span><span><span><span><span>一</span><span>)</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>否</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>全部</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>5:46:04 </span></span></span></span></p>
            </td>
            <span><span></span></span>
        </tr>
        <tr>
            <td vAlign=top width=114>
            <p><span><span><span><span>findAll()</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>子</span><span>(</span></span></span></span><span><span><span><span>多</span><span>)</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>是</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>全部</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>26.125</span></span></span></span><span><span><span><span>秒</span></span></span></span></p>
            </td>
            <span><span></span></span>
        </tr>
        <tr>
            <td vAlign=top width=114>
            <p><span><span><span><span>findAll()</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>父</span><span>(</span></span></span></span><span><span><span><span>一</span><span>)</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>是</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>全部</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>9.453</span></span></span></span><span><span><span><span>秒</span></span></span></span></p>
            </td>
            <span><span></span></span>
        </tr>
        <tr>
            <td vAlign=top width=114>
            <p><span><span><span><span>findPageByCriteria(dc,20,5478)</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>子</span><span>(</span></span></span></span><span><span><span><span>多</span><span>)</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>否</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>最后</span><span>20</span></span></span></span><span><span><span><span>条</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>1.469</span></span></span></span><span><span><span><span>秒</span></span></span></span></p>
            </td>
            <span><span></span></span>
        </tr>
        <tr>
            <td vAlign=top width=114>
            <p><span><span><span><span>findPageByCriteria(dc,20,547)</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>父</span><span>(</span></span></span></span><span><span><span><span>一</span><span>)</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>否</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>最后</span><span>20</span></span></span></span><span><span><span><span>条</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>12.235</span></span></span></span><span><span><span><span>秒</span></span></span></span></p>
            </td>
            <span><span></span></span>
        </tr>
        <tr>
            <td vAlign=top width=114>
            <p><span><span><span><span>findPageByCriteria(dc,20,5478)</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>子</span><span>(</span></span></span></span><span><span><span><span>多</span><span>)</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>是</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>最后</span><span>20</span></span></span></span><span><span><span><span>条</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>1.047</span></span></span></span><span><span><span><span>秒</span></span></span></span></p>
            </td>
            <span><span></span></span>
        </tr>
        <tr>
            <td vAlign=top width=114>
            <p><span><span><span><span>findPageByCriteria(dc,20,547)</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>父</span><span>(</span></span></span></span><span><span><span><span>一</span><span>)</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>是</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>最后</span><span>20</span></span></span></span><span><span><span><span>条</span></span></span></span></p>
            </td>
            <span><span></span></span>
            <td vAlign=top width=114>
            <p><span><span><span><span>1.000</span></span></span></span><span><span><span><span>秒</span></span></span></span></p>
            </td>
            <span><span></span></span>
        </tr>
    </tbody>
</table>
<img src ="http://www.blogjava.net/feifeirao/aggbug/120532.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/feifeirao/" target="_blank">五味子</a> 2007-05-28 17:44 <a href="http://www.blogjava.net/feifeirao/articles/120532.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Hibernate继承映射 </title><link>http://www.blogjava.net/feifeirao/articles/120518.html</link><dc:creator>五味子</dc:creator><author>五味子</author><pubDate>Mon, 28 May 2007 09:12:00 GMT</pubDate><guid>http://www.blogjava.net/feifeirao/articles/120518.html</guid><wfw:comment>http://www.blogjava.net/feifeirao/comments/120518.html</wfw:comment><comments>http://www.blogjava.net/feifeirao/articles/120518.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/feifeirao/comments/commentRss/120518.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/feifeirao/services/trackbacks/120518.html</trackback:ping><description><![CDATA[<p><font size=3><span>在对象导向设计中，继承关系是很常见的，但继承与关系型数据库有着先天上的差异，继承关系至表格的设计上有三种方式。</span></font></p>
<div>
<h2><font color=#003366><span><span>8</span></span><span><span><font face=宋体>．</font></span></span><span><span>1</span></span><span><span><font face=宋体>继承</font></span></span><span><span> - Table per concrete class</span></span></font></h2>
</div>
<p><font size=3><span>如果您采取的是对象模型的方式来设计程序，那么继承关系可能就会在您的程序设计中出现，然而关系型数据库的关联模型与对象模型并不匹配，为了映像对象模型</span><font face=Verdana> </font><span>与关联模型，您可以采取三种策略，这边先介绍最简单的一种：</span><span><font face=Verdana>Table per concrete class</font></span><span>，也就是每一个类别就对应一个表格。</span></font></p>
<p><span><font size=3>以实例来说明，如果您的程序中有以下的继承关系：</font></span><span><br></span></p>
<p><font size=3><span>以</span><span><font face=Verdana>Table per concrete class</font></span><span>的方式在关系型数据库中设计表格以作映像，就是直接对</span><span><font face=Verdana>DefaultUser</font></span><span>与</span><span><font face=Verdana>PowerUser</font></span><span>设计两个表格与之对应，如下：</span></font><span><br></span></p>
<p><font size=3><span>两个表格没有任何的关系，</span><span><font face=Verdana>defaultuser</font></span><span>与</span><span><font face=Verdana>poweruser</font></span><span>表格各自拥有</span><span><font face=Verdana>id</font></span><span>、</span><span><font face=Verdana>name</font></span><span>字段，您可以如下建立表格：</span></font></p>
<p><span><font size=3><font face="Times New Roman">CREATE TABLE defaultuser (</font></font></span></p>
<p><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>id INT(11) NOT NULL auto_increment PRIMARY KEY,</font></font></span></p>
<p><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>name VARCHAR(100) NOT NULL default '',</font></font></span></p>
<p><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>someProperty VARCHAR(100)</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">);</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">&nbsp;</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">CREATE TABLE poweruser (</font></font></span></p>
<p><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>id INT(11) NOT NULL auto_increment PRIMARY KEY,</font></font></span></p>
<p><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>name VARCHAR(100) NOT NULL default '',</font></font></span></p>
<p><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>otherProperty VARCHAR(100)</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">);</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">&nbsp;</font></font></span></p>
<p><span><font face="Times New Roman" size=3>User.java</font></span></p>
<p><em><span><font size=3><font face="Times New Roman">package onlyfun.caterpillar;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&nbsp;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">public class User {</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>private Integer id;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>private String name;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span></font></font></span></em></p>
<p><font size=3><em><span><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>// </font></span></em><em><span>必须要有一个预设的建构方法</span></em></font></p>
<p><em><span><font face="Times New Roman"><font size=3><span>&nbsp;&nbsp;&nbsp; </span>// </font></font></span></em><font size=3><em><span>以使得</span><span><font face="Times New Roman">Hibernate</font></span></em><em><span>可以使用</span><span><font face="Times New Roman">Constructor.newInstance()</font></span></em><em><span>建立对象</span></em></font></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>public User() {</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>}</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&nbsp;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>public Integer getId() {</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>return id;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>}</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&nbsp;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>public void setId(Integer id) {</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>this.id = id;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>}</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&nbsp;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>public String getName() {</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>return name;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>}</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&nbsp;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>public void setName(String name) {</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>this.name = name;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>}</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span></font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">}</font></font></span></em></p>
<p><span><font face="Times New Roman" size=3>DefaultUser.java</font></span></p>
<p><em><span><font size=3><font face="Times New Roman">package onlyfun.caterpillar;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&nbsp;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">public class DefaultUser extends User {</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>private String someProperty;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&nbsp;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>public DefaultUser() {</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>}</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&nbsp;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>public String getSomeProperty() {</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>return someProperty;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>}</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&nbsp;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>public void setSomeProperty(String someProperty) {</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>this.someProperty = someProperty;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>}</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">}</font></font></span></em></p>
<p><span><font size=3>在映射文件方面分别如下：</font></span></p>
<p><span><font face="Times New Roman" size=3>DefaultUser.hbm.xml</font></span></p>
<p><em><span><font size=3><font face="Times New Roman">&lt;?xml version="1.0" encoding="utf-8"?&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&lt;!DOCTYPE hibernate-mapping </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&nbsp;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&lt;hibernate-mapping&gt; </font></font></span></em></p>
<p><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span><em><span>&lt;class name="onlyfun.caterpillar.DefaultUser" table="defaultuser"&gt; </span></em></font></font></span></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;id name="id" column="id" type="java.lang.Integer"&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;generator class="native"/&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;/id&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;property name="name" column="name" type="java.lang.String"/&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span><span>&nbsp;&nbsp;&nbsp;&nbsp;</span>&lt;property name="someProperty" column="someProperty" type="java.lang.String"/&gt;<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>&lt;/class&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&lt;/hibernate-mapping&gt;</font></font></span></em></p>
<p><span><font face="Times New Roman" size=3>PowerUser.hbm.xml</font></span></p>
<p><em><span><font size=3><font face="Times New Roman">&lt;?xml version="1.0" encoding="utf-8"?&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&lt;!DOCTYPE hibernate-mapping </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&nbsp;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&lt;hibernate-mapping&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>&lt;class name="onlyfun.caterpillar.PowerUser" table="poweruser"&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;id name="id" column="id" type="java.lang.Integer"&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;generator class="native"/&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;/id&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;property name="name" column="name" type="java.lang.String"/&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;property name="otherProperty" column="otherProperty" type="java.lang.String"/&gt;<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>&lt;/class&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&lt;/hibernate-mapping&gt;</font></font></span></em></p>
<p><font size=3><span>当然，别忘了在</span><span><font face="Times New Roman">hibernate.cfg.xml</font></span><span>中定义使用这两个映射文件：</span></font></p>
<p><span><font face="Times New Roman" size=3>hibernate.cfg.xml</font></span></p>
<p><em><span><font size=3><font face="Times New Roman">&lt;?xml version="1.0" encoding="utf-8"?&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&lt;!DOCTYPE hibernate-configuration PUBLIC</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&nbsp;"-//Hibernate/Hibernate Configuration DTD 3.0//EN"</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"&gt;<span>&nbsp;&nbsp;&nbsp;&nbsp; </span></font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&lt;hibernate-configuration&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>&lt;session-factory&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>... </font></font></span></em></p>
<p><em><span><font face="Times New Roman"><font size=3><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;!-- </font></font></span></em><em><font size=3><span>对象与数据库表格映像文件</span><span><font face="Times New Roman"> --&gt; </font></span></font></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;mapping resource="onlyfun/caterpillar/DefaultUser.hbm.xml"/&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;mapping resource="onlyfun/caterpillar/PowerUser.hbm.xml"/&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>&lt;/session-factory&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&lt;/hibernate-configuration&gt;</font></font></span></em></p>
<p><font size=3><span>在储存对象时很简单，例如分别储存</span><span><font face=Verdana>DefaultUser</font></span><span>与</span><span><font face=Verdana>PowerUser</font></span><span>的实例：</span></font></p>
<p><em><span><font size=3><font face="Times New Roman">DefaultUser defaultUser = new DefaultUser();</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">defaultUser.setName("Bush");</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">defaultUser.setSomeProperty("hu....hu...");</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">PowerUser powerUser = new PowerUser();</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">powerUser.setName("caterpillar");</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">powerUser.setOtherProperty("Bla...Bla...");</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&nbsp;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">Session session = sessionFactory.openSession();</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">Transaction tx = session.beginTransaction();</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">session.save(powerUser); </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">session.save(defaultUser);</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">tx.commit();</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">session.close();</font></font></span></em></p>
<p><font size=3><span>至于查询方面，视您想查询哪个数据表，如果想同时查询</span><span><font face=Verdana>User</font></span><span>类对应的所有资料，则可以如下：</span></font></p>
<p><em><span><font size=3><font face="Times New Roman">Session session = sessionFactory.openSession();</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">Query query = session.createQuery("from onlyfun.caterpillar.User");</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">Iterator iterator = query.list().iterator();</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">while(iterator.hasNext()) {</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>User user = (User) iterator.next();</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>System.out.println(user.getName());</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">}</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&nbsp;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">session.close();</font></font></span></em></p>
<p><font size=3><span>这个查询会找出所有</span><span><font face=Verdana>User</font></span><span>之子类别所对应之数据，</span><span><font face=Verdana>Hibernate</font></span><span>实际上会使用以下的</span><span><font face=Verdana>SQL</font></span><span>进行查询：</span></font></p>
<p><span><font size=3><font face="Times New Roman">Hibernate: select defaultuse0_.id as id, defaultuse0_.name as name0_, defaultuse0_.someProperty as someProp3_0_ </font></font></span></p>
<p><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp; </span><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>from defaultuser defaultuse0_</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">Hibernate: select poweruser0_.id as id, poweruser0_.name as name1_, poweruser0_.otherProperty as otherPro3_1_ </font></font></span></p>
<p><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>from poweruser poweruser0_</font></font></span></p>
<p><font size=3><span>也就是</span><span>Hibernate</span><span>自动判断</span><span>User</span><span>的继承关系，并分别对</span><span>DefaultUser</span><span>与</span><span>PowerUser</span><span>对</span><span>应的表格进行查询。</span></font></p>
<p><font size=3><span>文件虽然很长，但其实不写这份文件也可以，还记得</span><font face=Verdana> </font><span>基本查询</span><font face=Verdana> </font><span>中曾经提过，如果您直接使用</span><span><font face=Verdana>"from java.lang.Object"</font></span><span>这样的</span><span><font face=Verdana>HQL</font></span><span>查询，所得到的结果是数据库中所有的数据，因为</span><span><font face=Verdana>Object</font></span><span>是</span><span><font face=Verdana>Java</font></span><span>中所有类别的父类别，写这份文件只是在加强您的印象，了解继承关系映像最基本的方式而已。</span></font></p>
<p><font size=3><span>父类别</span><span><font face=Verdana>User</font></span><span>对应的表格呢？这边没有建立，如果需要的话，就自己再建立一个吧！并撰写对应的映射文件就可以了。</span></font></p>
<div>
<h2><font color=#003366><span><span>8</span></span><span><span><font face=宋体>．</font></span></span><span><span>2</span></span><span><span><font face=宋体>继承</font></span></span><span><span> - Table per class hierarchy</span></span></font></h2>
</div>
<p><font size=3><span>接续</span><font face=Verdana> </font><span>上一个主题，</span><span><font face=Verdana>Table per concrete class</font></span><span>的继承映像方式是最简单，但没有效率（例如查询同为</span><span><font face=Verdana>User</font></span><span>类型时，需要两次</span><span><font face=Verdana>SQL</font></span><span>）且不易管理的映像方式，来看看继承关系映像至关系型数据库</span><font face=Verdana> </font><span>的第二种方式：</span><span><font face=Verdana>Table per class hierarchy</font></span><span>。</span></font></p>
<p><span><font size=3>这种方式使用一个表格储存同一个继承阶层的所有类别，并使用额外的字段来表示所记录的是哪一个子类别的数据。</font></span><span><br></span><font size=3><span>具体来说，对于继承</span><span><font face=Verdana>User</font></span><span>类别的</span><span><font face=Verdana>DefaultUser</font></span><span>及</span><span><font face=Verdana>PowerUser</font></span><span>，可以设计以下的表格来储存数据：</span></font><span><br></span></p>
<p><font size=3><span>可以使用以下的</span><span><font face=Verdana>SQL</font></span><span>来建立表格：</span></font></p>
<p><span><font size=3><font face="Times New Roman">CREATE TABLE user (</font></font></span></p>
<p><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>id INT(11) NOT NULL auto_increment PRIMARY KEY,</font></font></span></p>
<p><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>userType VARCHAR(50) NOT NULL,</font></font></span></p>
<p><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>name VARCHAR(100) NOT NULL default '',</font></font></span></p>
<p><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>someProperty VARCHAR(100),</font></font></span></p>
<p><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>otherProperty VARCHAR(100)</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">);</font></font></span></p>
<p><font size=3><span>现在所决定的是，如果要储存的数据是来自</span><span><font face=Verdana>DefalutUser</font></span><span>，则在</span><span><font face=Verdana>userType</font></span><span>记下</span><span><font face=Verdana>"Default"</font></span><span>，如果储存的数据来</span><span><font face=Verdana>PowerUser</font></span><span>，则</span><font face=Verdana> </font><span>在</span><span><font face=Verdana>userType</font></span><span>记下</span><span><font face=Verdana>"Power"</font></span><span>，由</span><span><font face=Verdana>userType</font></span><span>就可以在</span><span>数据从数据库取回时，决定其该封装为</span><span>DefaultUser</span><span>或是</span><span>PowerUser</span><span>，</span><span> </span><span>在使用</span><span>Hibernate</span><span>的话，这要在映射文件中使用</span><strong><span><font face=Verdana>&lt;discriminator&gt;</font></span></strong><span>等相关标签来定义，例如：</span></font></p>
<p><strong><span><font size=3><font face="Times New Roman">User.hbm.xml</font></font></span></strong></p>
<p><em><span><font size=3><font face="Times New Roman">&lt;?xml version="1.0" encoding="utf-8"?&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&lt;!DOCTYPE hibernate-mapping </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&nbsp;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&lt;hibernate-mapping&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>&lt;class name="onlyfun.caterpillar.User" table="user"&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;id name="id" column="id" type="java.lang.Integer"&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;generator class="native"/&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;/id&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;discriminator column="userType" type="java.lang.String"/&gt;<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;property name="name" column="name" type="java.lang.String"/&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><strong>&lt;subclass name="onlyfun.caterpillar.DefaultUser" </strong></font></font></span></em></p>
<p><strong><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>discriminator-value="Default"&gt; </font></font></span></em></strong></p>
<p><strong><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;property name="someProperty" </font></font></span></em></strong></p>
<p><strong><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>column="someProperty" </font></font></span></em></strong></p>
<p><strong><em><span><font size=3><font face="Times New Roman">&nbsp;<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>type="java.lang.String"/&gt; </font></font></span></em></strong></p>
<p><strong><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;/subclass&gt; </font></font></span></em></strong></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><strong>&nbsp;&lt;subclass name="onlyfun.caterpillar.PowerUser" </strong></font></font></span></em></p>
<p><strong><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>discriminator-value="Power"&gt; </font></font></span></em></strong></p>
<p><strong><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;property name="otherProperty" </font></font></span></em></strong></p>
<p><strong><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>column="otherProperty" </font></font></span></em></strong></p>
<p><strong><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>type="java.lang.String"/&gt; </font></font></span></em></strong></p>
<p><font size=3><font face="Times New Roman"><strong><em><span><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;/subclass&gt;<span>&nbsp;&nbsp; </span></span></em></strong><em><span><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span></span></em></font></font></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>&lt;/class&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&lt;/hibernate-mapping&gt;</font></font></span></em></p>
<p><font size=3><span>当然，别忘了在</span><span><font face=Verdana>hibernate.cfg.xml </font></span><span>中指定映像文件：</span></font><span><br></span><font size=3><strong><span>hibernate.cfg.xml</span></strong></font></p>
<p><em><span><font size=3><font face="Times New Roman">hibernate.cfg.xml</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&lt;?xml version="1.0" encoding="utf-8"?&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&lt;!DOCTYPE hibernate-configuration PUBLIC</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&nbsp;"-//Hibernate/Hibernate Configuration DTD 3.0//EN"</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"&gt;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp; </span></font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&lt;hibernate-configuration&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>&lt;session-factory&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>....</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&nbsp;</font></font></span></em></p>
<p><em><span><font face="Times New Roman"><font size=3><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;!-- </font></font></span></em><em><font size=3><span>对象与数据库表格映像文件</span><span><font face="Times New Roman"> --&gt; </font></span></font></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;mapping resource="onlyfun/caterpillar/User.hbm.xml"/&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>&lt;/session-factory&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&lt;/hibernate-configuration&gt;</font></font></span></em></p>
<p><font size=3><span>使用上一个主题中的储存程序的话，则</span><span><font face=Verdana>Hibernate</font></span><span>会使用以下的</span><span><font face=Verdana>SQL</font></span><span>来储存数据：</span></font></p>
<p><span><font size=3><font face="Times New Roman">Hibernate: insert into user (name, otherProperty, userType) values (?, ?, 'Power')</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">Hibernate: insert into user (name, someProperty, userType) values (?, ?, 'Default')</font></font></span></p>
<p><span><font size=3>而实际上数据表会储存以下的内容：</font></span></p>
<p><span><font size=3><font face="Times New Roman">+----+----------+-------------+-------------------+-------------------+</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">| id | userType | name<span>&nbsp;&nbsp;&nbsp;&nbsp; </span>| someProperty<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>| otherProperty<span>&nbsp;&nbsp;&nbsp;&nbsp; </span>|</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">+----+----------+-------------+-------------------+-------------------+</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">|&nbsp;1 | Power&nbsp;| caterpillar | NULL<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>| Bla...Bla...<span>&nbsp;&nbsp;&nbsp; </span>|</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">|&nbsp;2 | Default&nbsp;| Bush<span>&nbsp;&nbsp; </span>&nbsp;| hu....hu...<span>&nbsp;&nbsp;&nbsp;&nbsp; </span>| NULL<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>|</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">+----+----------+-------------+-------------------+-------------------+</font></font></span></p>
<p><font size=3><span>缺点就是，因子类别属性的不同，对映储存时会有许多字段没有数据，但查询效率较好，例如查询</span><span><font face=Verdana>User</font></span><span>类型的数据时，只需一次</span><span><font face=Verdana>SQL</font></span><span>，如使用</span><font face=Verdana> </font><span>上一个主题</span><font face=Verdana> </font><span>中的查询程序时，</span><span>Hibernate</span><span>会使用以下的</span><span>SQL</span><span>进行查询：</span></font></p>
<p><span><font size=3><font face="Times New Roman">Hibernate: </font></font></span></p>
<p><span><font size=3><font face="Times New Roman">&nbsp;select user0_.id as id, user0_.name as name0_, </font></font></span></p>
<p><span><font size=3><font face="Times New Roman">&nbsp;user0_.someProperty as someProp4_0_, user0_.otherProperty as otherPro5_0_, </font></font></span></p>
<p><span><font size=3><font face="Times New Roman">&nbsp;user0_.userType as userType from user user0_</font></font></span></p>
<div>
<h2><font color=#003366><span><span>8</span></span><span><span><font face=宋体>．</font></span></span><span><span>3</span></span><span><span><font face=宋体>继承</font></span></span><span><span> - Table per subclass</span></span></font></h2>
</div>
<p><font size=3><span>接续上一个主题，在使用</span><span><font face=Verdana>Table per class hierarchy</font></span><span>映像继承关系时，会有大量的字段有</span><span><font face=Verdana>NULL</font></span><span>的情况，好处是使用一个表格，查询时只需一次</span><span><font face=Verdana>SQL</font></span><span>。</span></font></p>
<p><font size=3><span><font face=Verdana>Table per subclass</font></span><span>的继承映像方式，给予父类与子类分别的表格，而父类与子类对应的表格透过外键来产生关联，具体的说，</span><span><font face=Verdana>User</font></span><span>类别、</span><span><font face=Verdana>DefaultUser</font></span><span>类别与</span><span><font face=Verdana>PowerUser</font></span><span>类别所映像的表格如下：</span></font><span><br></span></p>
<p><font size=3><span>其中</span><span><font face=Verdana>user</font></span><span>表格的</span><span><font face=Verdana>id</font></span><span>与</span><span><font face=Verdana>defaultuser</font></span><span>及</span><span><font face=Verdana>poweruser</font></span><span>的</span><span><font face=Verdana>id </font></span><span>一致，具体的说，在储存</span><span><font face=Verdana>DefaultUser</font></span><span>实例时，</span><span><font face=Verdana>id</font></span><span>与</span><span><font face=Verdana>name</font></span><span>属性记录在</span><span><font face=Verdana>user</font></span><span>表格中，而</span><span><font face=Verdana>someProperty</font></span><span>记录在</span><span><font face=Verdana> defaultuser</font></span><span>中，假设</span><span><font face=Verdana>user</font></span><span>表格的</span><span><font face=Verdana>id</font></span><span>值为</span><span><font face=Verdana>1</font></span><span>，则</span><span><font face=Verdana>defaultuser</font></span><span>表格对应的该笔记录其</span><span><font face=Verdana>id</font></span><span>值也会为一。</span></font></p>
<p><font size=3><span>可以使用以下的</span><span><font face="Times New Roman">SQL</font></span><span>建立资料表：</span></font></p>
<p><span><font size=3><font face="Times New Roman">CREATE TABLE user (</font></font></span></p>
<p><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>id INT(11) NOT NULL auto_increment PRIMARY KEY,</font></font></span></p>
<p><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>name VARCHAR(100) NOT NULL default ''</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">);</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">&nbsp;</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">CREATE TABLE defaultuser (</font></font></span></p>
<p><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>id INT(11) NOT NULL PRIMARY KEY,</font></font></span></p>
<p><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>someProperty VARCHAR(100)</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">);</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">&nbsp;</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">CREATE TABLE poweruser (</font></font></span></p>
<p><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>id INT(11) NOT NULL PRIMARY KEY,</font></font></span></p>
<p><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>otherProperty VARCHAR(100)</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">);</font></font></span></p>
<p><span><font size=3>在映射文件上，如下定义：</font></span></p>
<p><span><font face="Times New Roman" size=3>User.hbm.xml</font></span></p>
<p><em><span><font size=3><font face="Times New Roman">&lt;?xml version="1.0" encoding="utf-8"?&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&lt;!DOCTYPE hibernate-mapping </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&nbsp;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&lt;hibernate-mapping&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>&lt;class name="onlyfun.caterpillar.User" table="user"&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;id name="id" column="id" type="java.lang.Integer"&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;generator class="native"/&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;/id&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;property name="name" column="name" type="java.lang.String"/&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&nbsp;</font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><strong><span>&nbsp;&nbsp;</span>&lt;joined-subclass name="onlyfun.caterpillar.DefaultUser" </strong></font></font></span></em></p>
<p><strong><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>table="defaultuser"&gt;</font></font></span></em></strong></p>
<p><strong><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;key column="id"/&gt;<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></font></font></span></em></strong></p>
<p><strong><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;property name="someProperty" </font></font></span></em></strong></p>
<p><strong><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>column="someProperty" </font></font></span></em></strong></p>
<p><strong><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>type="java.lang.String"/&gt; </font></font></span></em></strong></p>
<p><strong><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;/joined-subclass&gt; </font></font></span></em></strong></p>
<p><strong><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></font></font></span></em></strong></p>
<p><strong><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;joined-subclass name="onlyfun.caterpillar.PowerUser" </font></font></span></em></strong></p>
<p><strong><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>table="poweruser"&gt;</font></font></span></em></strong></p>
<p><strong><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;key column="id"/&gt;<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span></font></font></span></em></strong></p>
<p><strong><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;property name="otherProperty" </font></font></span></em></strong></p>
<p><strong><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>column="otherProperty" </font></font></span></em></strong></p>
<p><strong><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>type="java.lang.String"/&gt; </font></font></span></em></strong></p>
<p><font size=3><font face="Times New Roman"><strong><em><span><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>&lt;/joined-subclass&gt; </span></em></strong><em><span><span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span></span></em></font></font></p>
<p><em><span><font size=3><font face="Times New Roman"><span>&nbsp;&nbsp;&nbsp; </span>&lt;/class&gt; </font></font></span></em></p>
<p><em><span><font size=3><font face="Times New Roman">&lt;/hibernate-mapping&gt;</font></font></span></em></p>
<p><font size=3><strong><span>&lt;joined-subclass&gt;</span></strong><strong><span>指明了子类别与所对应的表格</span></strong><span>，</span><strong><span>&lt;key column&gt;</span></strong><strong><span>指明子类别的对应表</span></strong><strong><span>格中，哪一个字段要与父类别的主键一致。</span></strong><strong></strong></font></p>
<p><font size=3><span>使用</span><font face=Verdana> </font><span>继承</span><span><font face=Verdana> - Table per concrete class </font></span><span>中的储存程序片段，则查询表格时可以发现以下的结果：</span></font></p>
<p><span><font size=3><font face="Times New Roman">mysql&gt; select * from user;</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">+-----+-------------+</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">| id&nbsp;| name<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>|</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">+-----+-------------+</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">|&nbsp;1&nbsp;| caterpillar |</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">|&nbsp;2&nbsp;| Bush<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>|</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">+-----+-------------+</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">2 rows in set (0.00 sec)</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">&nbsp;</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">mysql&gt; select * from defaultuser;</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">+----+-------------------+</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">| id | someProperty<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>|</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">+----+-------------------+</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">|&nbsp;2 | hu....hu...<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>|</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">+----+-------------------+</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">1 row in set (0.00 sec)</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">&nbsp;</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">mysql&gt; select * from poweruser;</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">+----+-------------------+</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">| id | otherProperty<span>&nbsp;&nbsp;&nbsp;&nbsp; </span>|</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">+----+-------------------+</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">|&nbsp;1 | Bla...Bla...<span>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>|</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">+----+-------------------+</font></font></span></p>
<p><span><font size=3><font face="Times New Roman">1 row in set (0.00 sec)</font></font></span></p>
<p><font size=3><span>仔细观察一下，看看</span><span><font face=Verdana>defaultuser</font></span><span>与</span><span><font face=Verdana>poweruser</font></span><span>表格中的</span><span><font face=Verdana>id</font></span><span>各自是对应于</span><span><font face=Verdana>user</font></span><span>表格中的哪笔数据。</span></font>&nbsp;</p>
<br><br>
<p id=TBPingURL>Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1305132</p>
<img src ="http://www.blogjava.net/feifeirao/aggbug/120518.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/feifeirao/" target="_blank">五味子</a> 2007-05-28 17:12 <a href="http://www.blogjava.net/feifeirao/articles/120518.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Hibernate继承映射时错误的解决方法 转</title><link>http://www.blogjava.net/feifeirao/articles/120516.html</link><dc:creator>五味子</dc:creator><author>五味子</author><pubDate>Mon, 28 May 2007 09:10:00 GMT</pubDate><guid>http://www.blogjava.net/feifeirao/articles/120516.html</guid><wfw:comment>http://www.blogjava.net/feifeirao/comments/120516.html</wfw:comment><comments>http://www.blogjava.net/feifeirao/articles/120516.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/feifeirao/comments/commentRss/120516.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/feifeirao/services/trackbacks/120516.html</trackback:ping><description><![CDATA[借助于Hibernate强大的O/R Mapping能力，我们能够通过discriminator轻易地将一颗继承树映射到一个表中，通过discriminator确定具体映射的子类。 <br><br>　　在设置@hibernate.discriminator column="type" type="integer"后，启动Hibernate报错：<br><br>Could not format discriminator value to SQL string<br><br>　　搜索Hibernate官方文档后发现问题，原来Hibernate默认的discriminator的type是String，当设置discriminator的type为integer后，需要为父类也设置@hibernate.class table="TABLE_NAME" discriminator-value="not null"，否则，Hibernate默认的discriminator-value是完整的类名，在转换String到int时造成NumberFormatException。<br><br>　　最后运行XDoclet，生成hbm文件：<br><br>
<table borderColor=#cccccc width="90%" align=center bgColor=#e3e3e3 border=1>
    <tbody>
        <tr>
            <td>＜?xml version="1.0" encoding="iso-8859-1"?＞<br>＜!DOCTYPE hibernate-mapping PUBLIC<br>"-//Hibernate/Hibernate Mapping DTD 3.0//EN" <br>"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"＞<br>＜hibernate-mapping＞<br>＜class name="com.crackj2ee.example.AbstractClass" table="TABLE_NAME" discriminator-value="not null"＞<br>＜id name="id" column="id" type="java.lang.Long" unsaved-value="null"＞<br>　＜generator class="increment"/＞<br>＜/id＞<br>＜discriminator column="type" not-null="true" type="integer"/＞<br>　＜subclass name="com.crackj2ee.example.SubClass1" discriminator-value="1"＞<br>　＜subclass name="com.crackj2ee.example.SubClass2" discriminator-value="2"＞<br>＜/class＞<br>＜/hibernate-mapping＞<br></td>
        </tr>
    </tbody>
</table>
&nbsp;<br><br>
<p id=TBPingURL>Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1594494</p>
<img src ="http://www.blogjava.net/feifeirao/aggbug/120516.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/feifeirao/" target="_blank">五味子</a> 2007-05-28 17:10 <a href="http://www.blogjava.net/feifeirao/articles/120516.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>重新学习 Hibernate fetch lazy cascade inverse 转</title><link>http://www.blogjava.net/feifeirao/articles/120515.html</link><dc:creator>五味子</dc:creator><author>五味子</author><pubDate>Mon, 28 May 2007 09:08:00 GMT</pubDate><guid>http://www.blogjava.net/feifeirao/articles/120515.html</guid><wfw:comment>http://www.blogjava.net/feifeirao/comments/120515.html</wfw:comment><comments>http://www.blogjava.net/feifeirao/articles/120515.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/feifeirao/comments/commentRss/120515.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/feifeirao/services/trackbacks/120515.html</trackback:ping><description><![CDATA[<p>Hibernate最让人头大的就是对集合的加载形式。<br>书看了N次了，还是没有真正理解Hibernate。所以下午专门做了下测试，对配置文件的意思加深了认识。<br><br>假设有两个表，Photos(一）&nbsp; ---&nbsp; picture(多）Photo包含picture集合<br><br>结论1： HQL代码 &gt; fetch（配置） &gt; lazy （配置）<br>结论2： 默认 lazy="true"<br>结论3： fetch 和 lazy 主要是用来级联查询的，&nbsp;&nbsp; 而 cascade 和 inverse 主要是用来级联插入和修改的<br>结论4： 如果你是用spring来帮你管理你的session, 并且是自动提交，延迟加载就等于没加载~_~(当然<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 除非你手动重新打开session然后手动Hibernate.initialize(set);然后关闭session.<br>结论5:&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;cascade主要是简化了在代码中的级联更新和删除。<br>j结论6：老爸可以有多个孩子，一个孩子不能有多个老爸，而且老爸说的算, 孩子围着老爸转。<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;所以Photos老爸要有权力所以 cascade&nbsp;这个关键子都是送给老爸的，&nbsp;也就是级联更新，<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 老爸改姓了，儿子也得跟着改，呵呵。&#8220;不然，就没有零花钱咯&#8221;。<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 而Picture儿子整体挨骂，但是还是要维护父子之间良好的关系，对老爸百依百顺，所<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 以老爸就说，儿子，&#8220;关系，由你来维护（inverse="true")&nbsp;，不然就不给零花钱。呵。&#8221;。<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;set name="pictures" inverse="true" cascade="all"&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;key&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;column name="photosid" not-null="true" /&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;/key&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;one-to-many class="girl.domain.Picture" /&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; &lt;/set&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<br>测试代码：<br><br>&nbsp;&nbsp;&nbsp;Photos p = ps.getById(1);<br>&nbsp;&nbsp;Set&lt;Picture&gt; set = p.getPictures();<br>&nbsp;&nbsp;for(Picture pic : set){<br>&nbsp; &nbsp;&nbsp;&nbsp;System.out.println(pic.getId());<br>&nbsp;&nbsp;}<br><br>&nbsp; 配置文件的一部分：<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;set name="pictures" inverse="true" cascade="all" &gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;key&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;column name="photosid" not-null="true" /&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;/key&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;one-to-many class="girl.domain.Picture" /&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;/set&gt;<br><br>测试过程会对配置文件不断修改：并且从来不曾手动重新打开session<br><br>测试结构：<br><br>当配置条件为 lazy=true 一句查询 测试代码中没有调用getPicture() &nbsp;正常 <br>Hibernate: select photos0_.id as id0_0_, photos0_.userid as userid0_0_, photos0_.typeid as typeid0_0_, photos0_.name as name0_0_, photos0_.createtime as createtime0_0_, photos0_.description as descript6_0_0_, photos0_.faceid as faceid0_0_, photos0_.uri as uri0_0_ from super.photos photos0_ where photos0_.id=?</p>
<p>lazy=true 一句查询 有getPicture()<br>Hibernate: select photos0_.id as id0_0_, photos0_.userid as userid0_0_, photos0_.typeid as typeid0_0_, photos0_.name as name0_0_, photos0_.createtime as createtime0_0_, photos0_.description as descript6_0_0_, photos0_.faceid as faceid0_0_, photos0_.uri as uri0_0_ from super.photos photos0_ where photos0_.id=?</p>
<p><br>lazy=true 一句查询&nbsp; 有getPicture() 并且访问了里面的元数Picture 且有异常抛出<br>Hibernate: select photos0_.id as id0_0_, photos0_.userid as userid0_0_, photos0_.typeid as typeid0_0_, photos0_.name as name0_0_, photos0_.createtime as createtime0_0_, photos0_.description as descript6_0_0_, photos0_.faceid as faceid0_0_, photos0_.uri as uri0_0_ from super.photos photos0_ where photos0_.id=?</p>
<p><br>lazy="false" 两句查询&nbsp; 肯定没问题，因为全部数据都个查了出来 所以怎么调用都正常<br>Hibernate: select photos0_.id as id0_0_, photos0_.userid as userid0_0_, photos0_.typeid as typeid0_0_, photos0_.name as name0_0_, photos0_.createtime as createtime0_0_, photos0_.description as descript6_0_0_, photos0_.faceid as faceid0_0_, photos0_.uri as uri0_0_ from super.photos photos0_ where photos0_.id=?<br>Hibernate: select pictures0_.photosid as photosid1_, pictures0_.id as id1_, pictures0_.id as id2_0_, pictures0_.photosid as photosid2_0_, pictures0_.name as name2_0_, pictures0_.clicked as clicked2_0_, pictures0_.uploaddate as uploaddate2_0_, pictures0_.size as size2_0_, pictures0_.description as descript7_2_0_, pictures0_.uri as uri2_0_ from super.picture pictures0_ where pictures0_.photosid=?</p>
<p><br>fetch="join"&nbsp; 一句查询&nbsp; 效果 ＝＝ lazy="false" 呵呵，哪个效率高，我就不知道了。。。。。。。。。。。<br>Hibernate: select photos0_.id as id0_1_, photos0_.userid as userid0_1_, photos0_.typeid as typeid0_1_, photos0_.name as name0_1_, photos0_.createtime as createtime0_1_, photos0_.description as descript6_0_1_, photos0_.faceid as faceid0_1_, photos0_.uri as uri0_1_, pictures1_.photosid as photosid3_, pictures1_.id as id3_, pictures1_.id as id2_0_, pictures1_.photosid as photosid2_0_, pictures1_.name as name2_0_, pictures1_.clicked as clicked2_0_, pictures1_.uploaddate as uploaddate2_0_, pictures1_.size as size2_0_, pictures1_.description as descript7_2_0_, pictures1_.uri as uri2_0_ from super.photos photos0_ left outer join super.picture pictures1_ on photos0_.id=pictures1_.photosid where photos0_.id=?</p>
<p>不加fetch＝"join" 一句查询&nbsp; 没有getPicture() 正常<br>Hibernate: select photos0_.id as id0_0_, photos0_.userid as userid0_0_, photos0_.typeid as typeid0_0_, photos0_.name as name0_0_, photos0_.createtime as createtime0_0_, photos0_.description as descript6_0_0_, photos0_.faceid as faceid0_0_, photos0_.uri as uri0_0_ from super.photos photos0_ where photos0_.id=?</p>
<p>不加fetch＝"join" 一句查询&nbsp; 有getPicture() 正常<br>Hibernate: select photos0_.id as id0_0_, photos0_.userid as userid0_0_, photos0_.typeid as typeid0_0_, photos0_.name as name0_0_, photos0_.createtime as createtime0_0_, photos0_.description as descript6_0_0_, photos0_.faceid as faceid0_0_, photos0_.uri as uri0_0_ from super.photos photos0_ where photos0_.id=?</p>
<p>不加fetch＝"join" 一句查询 有getPicture() 并且访问里面的元素Picture的ID 有异常抛出<br>Hibernate: select photos0_.id as id0_0_, photos0_.userid as userid0_0_, photos0_.typeid as typeid0_0_, photos0_.name as name0_0_, photos0_.createtime as createtime0_0_, photos0_.description as descript6_0_0_, photos0_.faceid as faceid0_0_, photos0_.uri as uri0_0_ from super.photos photos0_ where photos0_.id=?</p>
<p>来个两兵交战 fetch="join" lazy="true"&nbsp; 呵呵 结果，一句查询， 结构正常 所以就当lazy不存在好了。 看来fetch 是老大。、、、、、、、、、、、、、<br>Hibernate: select photos0_.id as id0_1_, photos0_.userid as userid0_1_, photos0_.typeid as typeid0_1_, photos0_.name as name0_1_, photos0_.createtime as createtime0_1_, photos0_.description as descript6_0_1_, photos0_.faceid as faceid0_1_, photos0_.uri as uri0_1_, pictures1_.photosid as photosid3_, pictures1_.id as id3_, pictures1_.id as id2_0_, pictures1_.photosid as photosid2_0_, pictures1_.name as name2_0_, pictures1_.clicked as clicked2_0_, pictures1_.uploaddate as uploaddate2_0_, pictures1_.size as size2_0_, pictures1_.description as descript7_2_0_, pictures1_.uri as uri2_0_ from super.photos photos0_ left outer join super.picture pictures1_ on photos0_.id=pictures1_.photosid where photos0_.id=?</p>
&nbsp;<br><br>
<p id=TBPingURL>Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1594975</p>
<img src ="http://www.blogjava.net/feifeirao/aggbug/120515.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/feifeirao/" target="_blank">五味子</a> 2007-05-28 17:08 <a href="http://www.blogjava.net/feifeirao/articles/120515.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>OracleLobHandler大字符</title><link>http://www.blogjava.net/feifeirao/articles/120427.html</link><dc:creator>五味子</dc:creator><author>五味子</author><pubDate>Mon, 28 May 2007 04:36:00 GMT</pubDate><guid>http://www.blogjava.net/feifeirao/articles/120427.html</guid><wfw:comment>http://www.blogjava.net/feifeirao/comments/120427.html</wfw:comment><comments>http://www.blogjava.net/feifeirao/articles/120427.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.blogjava.net/feifeirao/comments/commentRss/120427.html</wfw:commentRss><trackback:ping>http://www.blogjava.net/feifeirao/services/trackbacks/120427.html</trackback:ping><description><![CDATA[<p>private byte[] lwContent;&nbsp;&nbsp;&nbsp;<br>&lt;property<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; name="lwContent"<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; type="org.springframework.orm.hibernate3.support.BlobByteArrayType"<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; column="LW_CONTENT"<br>&nbsp;/&gt;<br>&nbsp;&lt;bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"&gt;<br>&nbsp;&nbsp;&lt;property name="dataSource"&gt;&lt;ref bean="dataSource"/&gt;&lt;/property&gt;<br>&nbsp;&lt;/bean&gt;<br>&nbsp;&nbsp;&nbsp; &lt;bean id="nativeJdbcExtractor" class="org.springframework.jdbc.support.nativejdbc.SimpleNativeJdbcExtractor" /&gt;<br>&nbsp;<br>&nbsp;&lt;bean id="oracleLobHandler" class="org.springframework.jdbc.support.lob.OracleLobHandler" lazy-init="true"&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;property name="nativeJdbcExtractor"&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;ref bean="nativeJdbcExtractor" /&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &lt;/property&gt;&nbsp;&nbsp;&nbsp;&nbsp; <br>&nbsp; &lt;/bean&gt;<br>&nbsp;&lt;bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"&gt;<br>&nbsp;&nbsp;&lt;property name="dataSource"&gt;&lt;ref local="dataSource"/&gt;&lt;/property&gt;<br>&nbsp;&nbsp;&lt;property name="mappingDirectoryLocations"&gt;<br>&nbsp;&nbsp;&nbsp;&lt;list&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&lt;value&gt;classpath:/gdhb/portal/persistence/xml&lt;/value&gt;<br>&nbsp;&nbsp;&nbsp;&lt;/list&gt;<br>&nbsp;&nbsp;&lt;/property&gt;</p>
<p>&nbsp;&nbsp;&lt;property name="hibernateProperties"&gt;<br>&nbsp;&nbsp;&nbsp;&lt;props&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&lt;prop key="hibernate.dialect"&gt;org.hibernate.dialect.OracleDialect&lt;/prop&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&lt;prop key="hibernate.show_sql"&gt;true&lt;/prop&gt;&nbsp;&nbsp;&nbsp;<br>&nbsp;&nbsp;&nbsp;&nbsp;<br>&nbsp;&nbsp;&nbsp;&lt;/props&gt;<br>&nbsp;&nbsp;&lt;/property&gt;<br>&nbsp;&nbsp;&lt;property name="lobHandler"&gt;&lt;ref bean="oracleLobHandler" /&gt; &lt;/property&gt;<br>&nbsp;&lt;/bean&gt;<br></p>
<img src ="http://www.blogjava.net/feifeirao/aggbug/120427.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.blogjava.net/feifeirao/" target="_blank">五味子</a> 2007-05-28 12:36 <a href="http://www.blogjava.net/feifeirao/articles/120427.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item></channel></rss>