在Hibernate3中,我们可以对实体的insert,update,delete操作进行定义,而无需完全依赖Hibernate提供的自动化操作接口.
对应Hibernate自定义持久化实现机制,配置文件中引入了以下3个新的节点定义:sql-insert,sql-update与sql-delete.通过这3个节点,我们可以直接指定用于实体insert,update,delete操作的SQL语句,从而避免了Hibernate自生成SQL所带来的局限.
对于Item映射,在Hibernate自定义持久化实现中,我们可以如下定义:
- <hibernate-mapping package="com.hpjianhua.hibernate.model">
- <class name="Item" table="t_items">
- <id name="itemNo">
- <generator class="assigned"/>
- </id>
- <property name="itemName" not-null="true"/>
- <property name="spec"/>
- <property name="pattern"/>
- <many-to-one name="category"/>
- <many-to-one name="unit"/>
- <sql-insert>
- INSERT INTO T_ITEM(ID,NAME,AGE) VALUES(?,?,?)
- </sql-insert>
- <sql-update>
- UPDATE T_ITEM SET NAME=?,AGE=? WHERE ID=?
- </sql-update>
- <sql-delete>
- DELETE FROM T_ITEM WHERE ID=?
- </sql-delete>
- </class>
- </hibernate-mapping>
sql-insert,sql-delete,sql-update 节点还拥有一个可选属性:callabel.如果此属性为true,则当前所定义的定点将被视为存储过程加以执行.
注意:Hibernate自定义持久化实现与Hibernate提供的内置支持配置文件是不一样的.自定义持久化实现的定义是在节点class内,而内置支持是与class节点同个级别的.
【编辑推荐】