当前位置: 首页 > 工具软件 > EasyDBO > 使用案例 >

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

桑成荫
2023-12-01

我们知道,在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开发文档。

另外,关于注解配置应该还会在正式版本中加入一些比较适用的内容,EasyDBO也还会作一些调整,请关注!

Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1351701

 类似资料: