4、注解反射生成SQL语句
.任务说明
2.代码实现
2.1 定义注解
- package dao;
- import java.lang.annotation.ElementType;
- import java.lang.annotation.Retention;
- import java.lang.annotation.RetentionPolicy;
- import java.lang.annotation.Target;
- @Target({ElementType.TYPE})
- @Retention(RetentionPolicy.RUNTIME)
- public @interface Table {
- String value();
- }
定义一个描述用户表属性字段的注解:
- package dao;
- import java.lang.annotation.ElementType;
- import java.lang.annotation.Retention;
- import java.lang.annotation.RetentionPolicy;
- import java.lang.annotation.Target;
- @Target({ElementType.FIELD})
- @Retention(RetentionPolicy.RUNTIME)
- public @interface Column {
- String value();
- }
2.2 定义映射到数据库的bean
- package dao;
- @Table("user")
- public class User {
- @Column("id")
- private int id;
- @Column("user_name")
- private String userName;
- @Column("nick_name")
- private String nickName;
- @Column("age")
- private int age;
- @Column("city")
- private String city;
- @Column("email")
- private String email;
- @Column("mobile")
- private String mobile;
- public int getId() {
- return id;
- }
- public void setId(int id) {
- this.id = id;
- }
- public String getUserName() {
- return userName;
- }
- public void setUserName(String userName) {
- this.userName = userName;
- }
- public String getNickName() {
- return nickName;
- }
- public void setNickName(String nickName) {
- this.nickName = nickName;
- }
- public int getAge() {
- return age;
- }
- public void setAge(int age) {
- this.age = age;
- }
- public String getCity() {
- return city;
- }
- public void setCity(String city) {
- this.city = city;
- }
- public String getEmail() {
- return email;
- }
- public void setEmail(String email) {
- this.email = email;
- }
- public String getMobile() {
- return mobile;
- }
- public void setMobile(String mobile) {
- this.mobile = mobile;
- }
- }
2.3 返回SQL查询语句的实现
根据参数动态返回查询语句:
- package dao;
- import java.lang.reflect.Field;
- import java.lang.reflect.Method;
- public class ReturnQuery {
- public static String query(Object u){
- StringBuilder sqlStrBuilder = new StringBuilder();
- //1.获取到Class
- Class c = u.getClass();
- //判断是否包含Table类型的注解
- if(!c.isAnnotationPresent(Table.class)){
- return null;
- }
- //2.获取到table的名字
- Table t = (Table) c.getAnnotation(Table.class);
- String tableName = t.value();
- //加入 where 1=1 ,是为了防止未来如果没有条件的情况下也不会报错
- sqlStrBuilder.append("select * from ").append(tableName).append(" where 1=1");
- Field[] fArray = c.getDeclaredFields(); //获取类属性的所有字段,
- //3.遍历所有的字段
- for (Field field : fArray) {
- //4.处理每个字段对应的sql
- //判断是否包含Column类型的注解
- if(!field.isAnnotationPresent(Column.class)){
- continue;
- }
- //4.1.拿到字段上面注解的值,即Column注解的值
- Column column = field.getAnnotation(Column.class);
- String columnName = column.value();
- //4.2.拿到字段的名
- String filedName = field.getName();
- //获取相应字段的getXXX()方法
- String getMethodName = "get" + filedName.substring(0, 1).toUpperCase()
- + filedName.substring(1);
- //字段的值
- Object fieldValue = null;//属性有int、String等,所以定义为Object类
- try {
- Method getMethod = c.getMethod(getMethodName);
- fieldValue = getMethod.invoke(u);
- } catch (Exception e) {
- e.printStackTrace();
- }
- //4.3.拼接sql
- if(fieldValue==null || (fieldValue instanceof Integer && (Integer)fieldValue==0)){
- continue;
- }
- sqlStrBuilder.append(" and ").append(filedName);
- if(fieldValue instanceof String){
- if(((String)fieldValue).contains(",")){
- String[] values = ((String)fieldValue).split(",");
- sqlStrBuilder.append(" in(");
- for (String v : values) {
- sqlStrBuilder.append("'").append(v).append("'").append(",");
- }
- sqlStrBuilder.deleteCharAt(sqlStrBuilder.length()-1);
- sqlStrBuilder.append(")");
- }
- else{
- sqlStrBuilder.append("=").append("'").append(fieldValue).append("'");
- }
- }
- else if(fieldValue instanceof Integer){
- sqlStrBuilder.append("=").append(fieldValue);
- }
- }
- return sqlStrBuilder.toString();
- }
- }
2.4 返回SQL语句的测试类
- package dao;
- public class Test {
- public static void main(String[] args) {
- User u1 = new User();
- u1.setId(9); //查询id为9的用户
- User u2 = new User();
- u2.setUserName("JTZeng"); //模糊查询用户名为JTZeng的用户
- u2.setAge(21);
- User u3 = new User();
- u3.setEmail("123@163.com,123@qq.com"); //查询邮箱有任意一个的用户
- String sql1 = ReturnQuery.query(u1); //查询id为9的用户
- String sql2 = ReturnQuery.query(u2); //查询用户名为JTZeng和年龄为21的用户
- String sql3 = ReturnQuery.query(u3); //查询邮箱中有任意一个的用户
- System.out.println(sql1);
- System.out.println(sql2);
- System.out.println(sql3);
- }
- }
4、注解反射生成SQL语句的更多相关文章
- 通过自定义注解反射生成SQL语句
----------------------------------------Program.cs---------------------------------------- using Sys ...
- C# - 通过自定义注解反射生成SQL语句[转]
转自http://blog.163.com/jong_cai/blog/static/87028045200902033553581/ -------------------------------- ...
- ASP.NET通过反射生成sql语句
最近对接一个接口,需要通过xml序列化成实体后添加额外信息后批量插入数据库,需要手动拼sql.因为涉及多张表,拼凑很麻烦而且容易出错,所以写了两个工具方法来生成sql,先写到博客里面,以便以后不时之需 ...
- 反射生成SQL语句入门
今天我们来学习学习通过反射技术来生成SQL语句. 反射提供了封装程序集.模块和类型的对象.您可以使用反射动态地创建类型的实例,将类型绑定到现有对象,或从现有对象中获取类型.然后,可以调用类型的方法或访 ...
- 利用反射生成SQL语句
// 修改学员信息的方法 public bool ModifyStudent(MODEL.Students model) { // 利用反映获取类对所有属性,用来动态生成SQL语句 StringBui ...
- 根据反射生成SQL语句
/** * 基础查询语句 * 返回类型的属性字符串Sql * @author: InkYi * 修改时间:2016年5月11日 - 上午10:06:00<br/> * 功能说明:<b ...
- 反射生成SQL语句
public static int Reg(Model ml) { bool b = true; Visit vt = new Visit(); StringBuilder builder = new ...
- Java 自定义注解及注解读取解析--模拟框架生成SQL语句
假设们使用一张简单的表,结构如下: 定义注解: 表注解: package com.xzlf.annotation; import java.lang.annotation.ElementType; i ...
- 利用反射自动生成SQL语句(仿Linq)
转:http://www.cnblogs.com/the7stroke/archive/2012/04/22/2465597.html using System; using System.Colle ...
随机推荐
- javascript 获取视口的高度和宽度
//获取视口的高度和宽度. function windowHeight() { var de = document.documentElement; return self.innerHeight|| ...
- Linux内核编译:很少有人提及的一些内容
1. 你可以使用O=参数将编译结果放到其他位置(非源代码目录),例如:make O=~/build ... 这样做的好处是你的源代码目录不会受到任何改变:你甚至可以在不同的体系结构间共享源代码. 注意 ...
- Python基础学习笔记,进阶学习笔记 出处
参考 虫师-博客 http://www.cnblogs.com/fnng/category 随笔分类相关文章
- ios关闭自动更新
iPhone系统更新超级烦人,避免测试机升级的方法 1. 设置禁用网络 设置-网线局域网-使用WLAN与蜂窝移动网的应用,将设置项设置为关闭 2. 一劳永逸,安装证书, 证书https://oldca ...
- 【RL前沿】深度强化学习的最新进展 by 2017.12.12
作者:Volodymyr Mnih Google DeepMind科学家. 在Geoffrey Hinton的指导下完成了多伦多大学的机器学习博士学位. 在此之前,在Csab Szepesvari的指 ...
- Mysql主从同步在线实施步骤【适合大数据库从库配置】
Mysql主从同步在线实施步骤[适合大数据库从库配置] MySQL的主从搭建大家有很多种方式,传统的mysqldump方式是很多人的选择之一,但比较适合在新实例中实施,对于较大的数据库则存在停机等不可 ...
- maven快速入门之安装
maven是基于项目对象模型(pom) 可以通过y一小段描述信息来管理项目的构建,报告,和文档的软件项目管理工具. 覆盖编译,测试运行清理构建周期,提供仓库的概念,统一帮助管理项目. 下载:http: ...
- sklearn的estimator
estimator的工作流程 在sklearn中,估计器(estimator)是一个重要的角色,分类器和回归器都属于estimator.在估计器中有有两个重要的方法是fit和transform. fi ...
- laravel5.4安装的报错
laravel5.4安装的报错 [InvalidArgumentException] Could not find package laravle/installer at any version f ...
- 0_Simple__simpleSeparateCompilation
▶ 简单的将纯 C/C++ 函数放到另一个文件中,利用头文件引用到主体 .cu 中来,编译时共同编译. ▶ 源代码,把 C++ 的部分去掉了 // simpleDeviceLibrary.cuh #i ...