整体思路是酱紫的:

给bean上注解说明该bean对应着数据库中哪张表,给每个bean的属性都注解说明各自对应着这张表的哪个字段。

通过类反射获取表名,通过逐个反射每个属性的getter方法,获取注解在属性上的字段名,以及属性值。

拿到表名、字段名、值,就可以拼接插入语句了。

细细道来

定义bean :

你需要定义一个有getter、setter及注解的bean,like this:

@Table(name = "PUPIL_STUDENT")

public class StudentBean {

@Column(name = "ROW_ID")

private String id;

@Column(name = "NAME")

private String name;

public String getId() {

return id;

}

public void setId(String id) {

this.id = id;

}

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

}

定义注解类:

使用注解的前提是你必须先定义注解类:

@Target(ElementType.TYPE)

@Retention(RetentionPolicy.RUNTIME)

public @interface Table

{

/**

* 数据库表名

*/

public abstract String name();

}

这是注解类的一般定义方法,三点说明:

1.使用@interface定义注解类;

2.@Retention(RetentionPolicy.RUNTIME) 表示该注解可以在运行期被读取;

3.@Target(ElementType.TYPE)表示这个注解只能被用到目标类(如StudentBean)的方法上。

Column注解类也是类似的定义方式。

 

反射获取Class与Method :

想要通过反射获取表名、字段名等,需要先获取类对象和方法对象(反射的惯用套路):

Class<?> clz = obj.getClass(); //obj就是bean对象的名称

Method[] methods = clz.getMethods();

获取表名:

获取表名的关键代码是:

Table _table = clazz.getAnnotation( Table.class );//获取注解类

String table_name = _table.name();//获取注解类的属性

通过bean上面的代码:@Table(name = "PUPIL_STUDENT") 就可以看出,获取的table_name就等于:”PUPIL_STUDENT”。

需要注意的地方是:

如果在当前类中并未找到Table注解,即:上面的_table变量为null,这时,你需要“上诉”到父类继续去寻找,也就是说,此时需要把clazz改为父类的Class实例:

clazz = clazz.getSuperclass();

然后再获取注解。这个逻辑应该要用到一个do{}while()循环吧。

获取每一个字段名:

通过Method[] methods = clz.getMethods()已经获取到所有方法了,遍历每个方法,我们现在的目标是,拿到属性值和属性上方的注解字段名。

对每一个method,调用getName()就能得到method的名称,然后拿到以”get”开头的方法。以getId()为例,这个方法的方法名为:”getId”,截取”get”之后的字符串,即:Id,然后将其首字母变为小写,即:id,就得到了一个属性名。其他属性名也是这样获取。

由于getter方法就是获取属性值的方法,那么通过反射技术:method.invoke(obj, new Object[]{});就获取到了该属性的值。

在反射技术中,变量对应的类是Field,既然拿到了变量名,那么通过变量名来获取对应的Field,再通过Field来获取变量(属性)上方的Column注解,再通过注解获取字段名称,一气呵成:

Field f= clz.getDeclaredField(m_name);

Column col = f.getAnnotation(Column.class);

String col_name = col.name();

表名有了,每一个字段名,字段值也有了,接下来就可以拼接成SQL了。


更多内容关注微信号:it_pupil

如何通过注解Bean类来封装SQL插入语句的更多相关文章

  1. 快速将一个表的数据生成SQL插入语句

    将一个表中的数据生成SQL插入语句,方便系统快速初始化,在数据库中执行创建以下过程就可以了. ) Drop Procedure GenerateData go CREATE PROCEDURE Gen ...

  2. [lua, mysql] 将多条记录数据组合成一条sql插入语句(for mysql)

    -- 演示将多条记录数据组合成一条sql插入语句(for mysql) function getTpl0(tname) -- 获取表各个字段 local t = { tpl_pack = {" ...

  3. jdbc操作根据bean类自动组装sql,天啦,我感觉我实现了hibernate

    场景:需要将从ODPS数仓中计算得到的大额可疑交易信息导入到业务系统的mysql中供业务系统审核.最简单的方式是用阿里云的组件自动进行数据同步了.但是本系统是开放是为了产品化,要保证不同环境的可移植性 ...

  4. 比较两个文件不同以及生成SQL插入语句

    Tips 做一个终身学习的人! 日拱一卒,功不唐捐. 今天有个小小的需求,具体需求是这样的: 有两个文本文件,每个文件都有一些字符串文本: 比较第一个文件中,在第二个文件中,不存在的字符串文本: 把这 ...

  5. 小程序实现sql插入语句转换成Laravel迁移语句

    sql的插入语句长这样: INSERT INTO `media` (`MediaID`, `type`, `filename`, `title`) VALUES (1, 'word', 'word1. ...

  6. SQL 插入语句汇总

    INSERT VALUES 插入一行或多行到目标表中 -- single row INSERT INTO Sales.MyOrders(custid, empid, orderdate, shipco ...

  7. 最新省市区数据,sql插入语句

    --省数据 insert into Province (ProvinceName)  values('北京市'); insert into Province (ProvinceName)  value ...

  8. pL/Sql插入语句时报错,对表空间没有权限 对表空间 'USERS' 无权限

    进入dba为其授予权限:sqlplus sys/admin as sysdba; 为用户授予权限即可 grant unlimited tablespace to username;

  9. sql插入语句笔记

    使用INSERT插入数据行 [一次插入一行数据] 全写: INSERT  INTO  renshi  (name, sex, age ,tel) VALUES  ('胡大姐','女','35','13 ...

随机推荐

  1. C++中string

    之所以抛弃char*的字符串而选用C++标准程序库中的string类,是因为他和前者比较起来,不必 担心内存是否足够.字符串长度等等,而且作为一个类出现,他集成的操作函数足以完成我们大多数情况下(甚至 ...

  2. 【转】50条大牛C++编程开发学习建议

    每个从事C++开发的朋友相信都能给后来者一些建议,但是真正为此进行大致总结的很少.本文就给出了网上流传的对C++编程开发学习的50条建议,总结的还是相当不错的,编程学习者(不仅限于C++学习者)如果真 ...

  3. mysql 省市联动sql 语句

    /*MySQL Data TransferSource Host: localhostSource Database: virgoTarget Host: localhostTarget Databa ...

  4. IOS开发中如何使用通知NSNotification传值

    通知 是在跳转控制器之间常用的传值代理方式,除了代理模式,通知更方便.便捷,一个简单的Demo实现通知的跳转传值. 输入所要发送的信息 ,同时将label的值通过button方法调用传递, - (IB ...

  5. Heka GeoIpDecoder 配置

    Prepare: 安装geoip-api-c,确保/usr/include/GeoIP.h存在: 源码编译安装Heka (容易出现问题): 下载GeoLiteCity.dat数据库. 配置文件举例: ...

  6. Linux FTP 服务器配置简单说明

    一.  FTP 说明 linux 系统下常用的FTP 是vsftp, 即Very Security File Transfer Protocol. 还有一个是proftp(Profession ftp ...

  7. KNN算法--物以类聚,人以群分

    KNN(K Nearest Neighbors,K近邻 )算法是机器学习所有算法中理论最简单,最好理解的.KNN是一种基于实例的学习,通过计算新数据与训练数据特征值之间的距离,然后选取K(K>= ...

  8. C语言的位运算的优势

    位运算加速技巧1. 如果乘上一个2的倍数数值,可以改用左移运算(Left Shift) 加速 300% x = x * 2;x = x * 64;//改为:x = x << 1; // 2 ...

  9. jQuery 的 ready 函数是如何工作的?(源码分析)

    如果你使用过 jQuery , 就必然使用过 ready 函数,它用来注册当页面准备好之后可以执行的函数. 问题来啦,我们的页面什么时候准备好了呢? 1. onload 事件 最基本的处理方式就是页面 ...

  10. Flash安全的一些总结

    整理了下Flash安全相关的知识,后面会再完善 一.先来说crossdomain.xml这个文件 flash如何跨域通信,全靠crossdomain.xml这个文件.这个文件配置在服务端,一般为根目录 ...