我们知道,在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也还会作一些调整,请关注!
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也还会作一些调整,请关注!