随笔 - 115  文章 - 481  trackbacks - 0
<2006年10月>
24252627282930
1234567
891011121314
15161718192021
22232425262728
2930311234

常用链接

留言簿(19)

随笔档案(115)

文章档案(4)

新闻档案(1)

成员连接

搜索

  •  

最新评论

阅读排行榜

评论排行榜

  我们知道,在EasyDBO最后一个测试版本中,增加了使用注解来配置对象及关系表映射的功能。前段时间看到有人在问注解中怎么配置主键属性及主键生成器,由于在开发文档中使用的是默认配置,所以文档中使用了下面的例子:
import java.io.Serializable;
import java.util.Date;import com.easyjf.dbo.annotation.*;
@Table(tableName="message")
publicclass Message implements Serializable{
  @TableField(name="cid")
  privateString cid;
  @TableField(name="title")
  private String title1;
  @TableField(name="content")
  private String content1;
  @TableField(name="inputUser")
  private String inputUser;
  @TableField(name="inputTime")
  private Date inputTime;
  @TableField(name="publish")
  private Boolean publish1;
  @TableField(name="status")
  private Integer status1;
  public String getCid() {
    return cid;
  }
  publicvoid setCid(String cid) {
    this.cid = cid;
  }
  //...
  //其它的getter及setter方法
}
 
 这里面没有演示怎么配置主键属性及生成器,我们分别来看看@Table及@TabelField两个标签的源代码:
 
package com.easyjf.dbo.annotation;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
/**
 * 用于定义表结构的标签
 * @author 大峡
 *
 */
@Retention(RetentionPolicy.RUNTIME)
public @interface Table {
 /**
  * 表名
  * @return
  */
 String tableName();
 /**
  * 表主键
  * @return
  */
 String keyField() default "cid";
 /**
  * 主键值生成器
  * @return
  */
 String keyGenerator() default "com.easyjf.dbo.RandomIdGenerator"; 
 
}
 
  由源码可以看到,@Table有三个属性,tableName用来定义表名,keyField用来定义主键属性,keyGenerator用来定义主键生成器。而keyField与keyGenerator有一个默认值,前面的Message类定义由于使用了默认值,因此没有使用keyField及keyGenerator。若要自定义自己的默认值,可以写成如下形势:
@Table(tableName="message",keyField="id",keyGenerator="com.easyjf.dbo.NullIdGenerator")
publicclass Message implements Serializable{
  ...
}
 
 
  再来看看@TableField的源文件:
package com.easyjf.dbo.annotation;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
/**
 * 用于定义表字段的标签
 * @author 大峡
 *
 */
@Retention(RetentionPolicy.RUNTIME)
public @interface TableField
{
 public String name() ;  
 boolean lazy() default false;
 boolean unique() default false;
}
 
  由于已经把lazy及unique给了默认值,所以我们看到示例中只定义了属性对应的例即可。
 
  @TableField只定义了普通的属性,另外还有OneToOne、ManyToOne、ManyToMany等属性,详细请参考EasyDBO开发文档
      http://www.easyjf.com/easydbo/devguide.htm
 
  另外,关于注解配置应该还会在正式版本中加入一些比较适用的内容,EasyDBO也还会作一些调整,请关注!

(本文作者 EasyJF开源 大峡)
posted on 2006-10-26 10:08 简易java框架 阅读(1046) 评论(0)  编辑  收藏

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


网站导航: