注册
 找回密码
 注册
江西广告网
查看: 468|回复: 0
打印 上一主题 下一主题

EasyDBO中Java注解配置映射的原理及使用

[复制链接]

该用户从未签到

1
跳转到指定楼层
发表于 2009-3-17 08:14:33 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?注册

x
  我们知道,在EasyDBO最后一个测试版本中,增加了使用注解来配置对象及关系表映射的功能。前段时间看到有人在问注解中怎么配置主键属性及主键生成器,由于在开发文档中使用的是默认配置,所以文档中使用了下面的例子: import java.io.Serializable; import java.util.Date;import com.easyjf.dbo.annotation.*; @Table(tableName="message") public class Message implements Serializable{   @TableField(name="cid")   private String 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;   }   public void 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") public class 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也还会作一些调整,请关注!
您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表