Java Annotation通过自定义注解方式 对每个字段或者字段组合进行条件检索

3 篇文章 0 订阅
3 篇文章 0 订阅

通过自定义注解方式 对每个字段或者字段组合进行条件检索

项目需求

有一张表 包含 id username nickName age等字段,为了方便对每个字段或者字段的组合进行条件检索,并打印sql语句

项目实现

代码中注释写的比较全,就不在啰嗦了,直接看代码

实体类
/**
 * Create by marven
 * Create date for 14:45 2020/3/12
 * Description: 人员实体
 **/
@Table("user")
public class PersoBean {

    /**
     * 用户id
     */
    @Column("id")
    private Integer id;

    /**
     * 用户名称
     */
    @Column("username")
    private String username;

    /**
     * 用户昵称
     */
    @Column("nickname")
    private String nickname;

    /**
     * 用户年龄
     */
    @Column("age")
    private Integer age;

    public Integer getId() {
        return id;
    }

    public void setId(Integer 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 Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }
}
Table注解类
package com.example.demo.demo.Annotation;

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

/**
 * Create by marven
 * Create date for 14:49 2020/3/12
 * Description:数据库表
 **/
@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
public @interface Table {
    String value();
}

Column注解类
package com.example.demo.demo.Annotation;

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

/**
 * Create by marven
 * Create date for 14:51 2020/3/12
 * Description:数据库列
 **/
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.FIELD})
public @interface Column {
    String value();
}

测试类 程序入口类
 public static void main(String args[]){
        PersoBean bean1 = new PersoBean();
        bean1.setId(10);

        PersoBean bean2 = new PersoBean();
        bean2.setNickname("marven");

        PersoBean bean3 = new PersoBean();
        bean3.setAge(18);

        String  sql1 =  sql(bean1);
        String  sql2 =  sql(bean2);
        String  sql3 =  sql(bean3);

        System.out.println(sql1);
        System.out.println(sql2);
        System.out.println(sql3);
    }
    private static String  sql(PersoBean bean){
        StringBuilder stringBuilder = new StringBuilder();
        try {
            // 获取类加载器
            Class c = bean.getClass();
            stringBuilder.append("select * from ");
            // 拼接表名
            //  获取到表的注解
            boolean isTableAnnotationExist = c.isAnnotationPresent(Table.class);
            if(!isTableAnnotationExist){
                return null;
            }
            // 获取到Table的注解
            Table tableAnnotation = (Table) c.getAnnotation(Table.class);
            // 获取到注解的值
            String tableName = tableAnnotation.value();
            // 拼接表名
            stringBuilder.append(tableName);
            // select * from user where 1= 1
            stringBuilder.append(" where 1 = 1");
            // 获取到所有的字段
            Field[] arrayFields = c.getDeclaredFields();
            // 对所有的字段进行遍历
            for(Field field : arrayFields){
                boolean isFieldAnnotationExist = field.isAnnotationPresent(Column.class);
                if(!isFieldAnnotationExist){
                   continue;
                }
                Column column =  field.getAnnotation(Column.class);
                // 获取到表字段名称
                String columnName = column.value();
                // 获取到字段方法名 eg getId
                String methodName = "get"+columnName.substring(0,1).toUpperCase()+columnName.substring(1);
                // 获取到这个类中的方法
                Method method =  c.getMethod(methodName);
                // 调用这个方法  invoke 获取到属性值
                Object obj = method.invoke(bean);
                if(obj == null || (obj instanceof Integer && (Integer)obj == 0)){
                    continue;
                }
                stringBuilder.append(" and ").append(columnName);
                 // 如果值是字符串  在sql中使用‘’包装
                if(obj instanceof String){
                    stringBuilder .append("=").append("'").append(obj).append("'");
                }else if(obj instanceof Integer){
                    stringBuilder.append("=").append(obj);
                }
//
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        return stringBuilder.toString();
    }

}
执行截图

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中,我们可以通过自定义注解方式为某一字段赋值。首先,我们需要定义一个注解,使用@interface关键字声明,并可以在注解内部定义一些属性。接下来,在需要赋值的字段上,通过在字段前加上该注解的方式来使用自定义注解。 首先,我们创建一个自定义注解,例如@MyAnnotation: ```java import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; @Retention(RetentionPolicy.RUNTIME) // 指定注解的生命周期为运行时 @Target(ElementType.FIELD) // 指定注解的作用目标为字段 public @interface MyAnnotation { String value(); // 定义一个属性value,用于赋值 } ``` 然后,我们可以在需要赋值的字段上使用@MyAnnotation注解,并通过value属性给字段赋值: ```java public class MyClass { @MyAnnotation("Hello") // 通过@MyAnnotation注解给field赋值为"Hello" private String field; public String getField() { return field; } public void setField(String field) { this.field = field; } } ``` 最后,我们可以使用反射获取字段的注解信息,并获取注解中的值,实现给字段赋值的功能: ```java import java.lang.reflect.Field; public class Main { public static void main(String[] args) throws Exception { MyClass obj = new MyClass(); Field field = obj.getClass().getDeclaredField("field"); // 获取字段 MyAnnotation annotation = field.getAnnotation(MyAnnotation.class); // 获取字段上的注解 if (annotation != null) { String value = annotation.value(); // 获取注解的值 field.setAccessible(true); // 设置字段可访问 field.set(obj, value); // 给字段赋值 } System.out.println(obj.getField()); // 输出 "Hello" } } ``` 通过以上方法,我们可以通过自定义注解方式为某一字段赋值,实现更加灵活和可扩展的代码编写方式

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值