通过Java 注解以及反射机制实现Java对象属性与数据库表字段的映射

所用到的类有如下:

DBTable.java(数据库表名描述注解)

 

package com.ark3g.test;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * 
 * @see com.ark3g.test.DBTable
 *       数据库表名描述注解
 * @version 1.0, 2012-12-10 上午11:45:18
 * @author danny.zhang
 */
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
public @interface DBTable {
  
    public String name() default "";
}

 

ColumnInteger.java(数据库列描述注解int类型)

package com.ark3g.test;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * 
 * @see com.ark3g.test.ColumnInteger
 *       数据库列描述注解int类型
 * @version 1.0, 2012-12-10 上午11:40:23
 * @author danny.zhang
 */
//声明注解用在成员变量上
@Target(ElementType.FIELD)
//声明注解运行级别在JVM
@Retention(RetentionPolicy.RUNTIME)

public @interface ColumnInteger {
    //name其实就是改注解的成员变量
    public String name() default "";
    public Constraint constraint() default @Constraint;
}


ColumnString.java(数据库列描述注解varchar类型)

package com.ark3g.test;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * 
 * @see com.ark3g.test.ColumnString
 *       数据库列描述注解varchar类型
 * @version 1.0, 2012-12-10 上午11:42:45
 * @author danny.zhang
 */
@Target(ElementType.FIELD)
@Retention(RetentionPolicy.RUNTIME)
public @interface ColumnString {
    public int value() default -1;
    public String name() default "";
    public Constraint constriant() default @Constraint;
}

 


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值