Junky's IT Notebook

统计

留言簿(8)

积分与排名

WebSphere Studio

阅读排行榜

评论排行榜

hibernate对视图的操作

      由于视图没有主键,所以在用hibernate对视图操作就需要做点处理了,网上搜了一通也没能找到相关文章,后来突然想到了myeclipse可以帮助生成hibernate的配置文件和对应的pojo代码。
      打开myeclipse,选择相关的视图,生成了配置文件和pojo类,发现pojo类生成了两个,而配置文件却一个,参看了配置文件和类,明白了是怎么回事。生成的配置文件通过了组合的方式生成,所以会对应两个类,一个类主要存放id信息,以个类存放对应的字段信息。
      下面是生成的类和配置文件:
类:
public class AllTablePb implements Serializable {

 // Fields
 private AllTablePbId id;

 // Property accessors
 public AllTablePbId getId() {
  return this.id;
 }

 public void setId(AllTablePbId id) {
  this.id = id;
 }
}

public class AllTablePbId implements java.io.Serializable {

 // Fields

 private String owner;

 private String tableName;

 private String columnName;

 private String dataType;

 private String pbcCnam;

 private String pbcCmnt;

 // Property accessors

 public String getOwner() {
  return this.owner;
 }

 public void setOwner(String owner) {
  this.owner = owner;
 }

 public String getTableName() {
  return this.tableName;
 }

 public void setTableName(String tableName) {
  this.tableName = tableName;
 }

 public String getColumnName() {
  return this.columnName;
 }

 public void setColumnName(String columnName) {
  this.columnName = columnName;
 }

 public String getDataType() {
  return this.dataType;
 }

 public void setDataType(String dataType) {
  this.dataType = dataType;
 }

 public String getPbcCnam() {
  return this.pbcCnam;
 }

 public void setPbcCnam(String pbcCnam) {
  this.pbcCnam = pbcCnam;
 }

 public String getPbcCmnt() {
  return this.pbcCmnt;
 }

 public void setPbcCmnt(String pbcCmnt) {
  this.pbcCmnt = pbcCmnt;
 }

}

配置文件:
<hibernate-mapping>
 <class name="com.hhkj.workflow.bean.AllTablePb" table="V_ALLTAB_PB" schema="CANP">
  <composite-id name="id" class="com.hhkj.workflow.bean.AllTablePbId">
   <key-property name="owner" type="string">
    <column name="OWNER" length="30" />
   </key-property>
   <key-property name="tableName" type="string">
    <column name="TABLE_NAME" length="30" />
   </key-property>
   <key-property name="columnName" type="string">
    <column name="COLUMN_NAME" length="30" />
   </key-property>
   <key-property name="dataType" type="string">
    <column name="DATA_TYPE" length="106" />
   </key-property>
   <key-property name="pbcCnam" type="string">
    <column name="PBC_CNAM" length="30" />
   </key-property>
   <key-property name="pbcCmnt" type="string">
    <column name="PBC_CMNT" length="254" />
   </key-property>
  </composite-id>
 </class>
</hibernate-mapping>
这样就可以通过AllTablePb.getId()取得相关的信息。
      感觉myeclipse的确不错,特别是对于使用hibernate还不是非常熟练的人来说,通过它可以帮解决不少问题。
      通过这样对视图的操作,同样也可以用到对于那些没有定义主键的表,操作方法是一样的。
      呵呵,个人的一点体会,欢迎大家多提意见。

posted on 2006-06-02 00:17 junky 阅读(802) 评论(1)  编辑  收藏 所属分类: hibernate

评论

# re: hibernate对视图的操作 2006-06-18 05:56 阿花

那你是如何 取得数据库中某个字段值得呢。
我的 <hibernate-mapping>
<class name="com.darkrainnight.base.adminuserinfo.AdminUserInfo" table="admin_user_info" catalog="rain">
<composite-id name="id" class="com.darkrainnight.base.adminuserinfo.AdminUserInfoId">
<key-property name="id" type="string">
<column name="id" length="4" />
</key-property>
<key-property name="username" type="string">
<column name="username" length="10" />
</key-property>
<key-property name="reason" type="string">
<column name="reason" />
</key-property>
<key-property name="email" type="string">
<column name="email" length="80" />
</key-property>
<key-property name="createDate" type="date">
<column name="create_date" length="10" />
</key-property>
</composite-id>
</class>
</hibernate-mapping>
我想取得 数据库id号的最大值,有没有直接的sql语句呢  回复  更多评论   


只有注册用户登录后才能发表评论。


网站导航: