注解:java 自定义注解应用实例

简介: 本例子旨在使用自定义注解为实体打上标记,为自动生成 sql 提供依据,模拟 hibernate 的注解,至于注解的原理自己搜吧1.定义 Table 注解 [java] view plain copy package test;    import java.

本例子旨在使用自定义注解为实体打上标记,为自动生成 sql 提供依据,模拟 hibernate 的注解,至于注解的原理自己搜吧

1.定义 Table 注解

 

[java]  view plain  copy
 
  1. package test;  
  2.   
  3. import java.lang.annotation.Documented;  
  4. import java.lang.annotation.ElementType;  
  5. import java.lang.annotation.Inherited;  
  6. import java.lang.annotation.Retention;  
  7. import java.lang.annotation.RetentionPolicy;  
  8. import java.lang.annotation.Target;  
  9.   
  10. @Inherited  
  11. @Target({ElementType.TYPE})  
  12. @Retention(RetentionPolicy.RUNTIME)  
  13. @Documented  
  14. public @interface Table {  
  15.     String value() default "";  
  16. }  


2.定义 Column 注解

 

 

[java]  view plain  copy
 
  1. package test;  
  2.   
  3. import java.lang.annotation.Documented;  
  4. import java.lang.annotation.ElementType;  
  5. import java.lang.annotation.Inherited;  
  6. import java.lang.annotation.Retention;  
  7. import java.lang.annotation.RetentionPolicy;  
  8. import java.lang.annotation.Target;  
  9.   
  10. @Inherited  
  11. @Target({ElementType.FIELD})  
  12. @Retention(RetentionPolicy.RUNTIME)  
  13. @Documented  
  14. public @interface Column {  
  15.     String value() default "";  
  16. }  


3.定义使用注解的实体

 

 

[java]  view plain  copy
 
  1. package test;  
  2.   
  3.   
  4. @Table("tb_test")  
  5. public class TestDto {  
  6.       
  7.     @Deprecated  
  8.     private String tt;  
  9.       
  10.     @Column("_id")  
  11.     private String id;  
  12.       
  13.     @Column("username")  
  14.     private String name;  
  15.       
  16.     public TestDto(String id, String name) {  
  17.         super();  
  18.         this.id = id;  
  19.         this.name = name;  
  20.     }  
  21.   
  22.     public String getId() {  
  23.         return id;  
  24.     }  
  25.   
  26.     public void setId(String id) {  
  27.         this.id = id;  
  28.     }  
  29.   
  30.     public String getName() {  
  31.         return name;  
  32.     }  
  33.   
  34.     public void setName(String name) {  
  35.         this.name = name;  
  36.     }  
  37.       
  38.       
  39. }  


4.测试注解

 

 

[java]  view plain  copy
 
  1. package test;  
  2.   
  3. import java.lang.reflect.Field;  
  4. import java.lang.reflect.Method;  
  5.   
  6. public class Test {  
  7.     public static void main(String[] args) {  
  8.         TestDto testDto = new TestDto("123", "34");  
  9.         TestDto testDto1 = new TestDto("123", "test1");  
  10.         TestDto testDto2 = new TestDto("", "test1,test2,test3,test4");  
  11.         String sql = assembleSqlFromObj(testDto);  
  12.         String sql1 = assembleSqlFromObj(testDto1);  
  13.         String sql2 = assembleSqlFromObj(testDto2);  
  14.         System.out.println(sql);  
  15.         System.out.println(sql1);  
  16.         System.out.println(sql2);  
  17.     }  
  18.   
  19.     /** 
  20.      * 通过注解来组装查询条件,生成查询语句 
  21.      *  
  22.      * @param obj 
  23.      * @return 
  24.      */  
  25.     public static String assembleSqlFromObj(Object obj) {  
  26.         Table table = obj.getClass().getAnnotation(Table.class);  
  27.         StringBuffer sbSql = new StringBuffer();  
  28.         String tableName = table.value();  
  29.         sbSql.append("select * from " + tableName + " where 1=1 ");  
  30.         Field[] fileds = obj.getClass().getDeclaredFields();  
  31.         for (Field f : fileds) {  
  32.             String fieldName = f.getName();  
  33.             String methodName = "get" + fieldName.substring(0, 1).toUpperCase()  
  34.                     + fieldName.substring(1);  
  35.             try {  
  36.                 Column column = f.getAnnotation(Column.class);  
  37.                 if (column != null) {  
  38.                     Method method = obj.getClass().getMethod(methodName);  
  39.                     String value = (String) method.invoke(obj);  
  40.                     if (value != null && !value.equals("")) {  
  41.                         if (!isNum(column.value()) && !isNum(value)) {  
  42.                             // 判断参数是不是 in 类型参数 1,2,3  
  43.                             if (value.contains(",")) {  
  44.                                 sbSql.append(" and " + column.value() + " in (" + value + ") ");  
  45.                             } else {  
  46.                                 sbSql.append(" and " + column.value() + " like '%" + value + "%' ");  
  47.                             }  
  48.                         } else {  
  49.                             sbSql.append(" and " + column.value() + "=" + value + " ");  
  50.                         }  
  51.                     }  
  52.                 }  
  53.             } catch (Exception e) {  
  54.                 e.printStackTrace();  
  55.             }  
  56.         }  
  57.         return sbSql.toString();  
  58.     }  
  59.   
  60.     /** 
  61.      * 检查给定的值是不是 id 类型 1.检查字段名称 2.检查字段值 
  62.      *  
  63.      * @param target 
  64.      * @return 
  65.      */  
  66.     public static boolean isNum(String target) {  
  67.         boolean isNum = false;  
  68.         if (target.toLowerCase().contains("id")) {  
  69.             isNum = true;  
  70.         }  
  71.         if (target.matches("\\d+")) {  
  72.             isNum = true;  
  73.         }  
  74.         return isNum;  
  75.     }  
  76. }  


测试结果:

 

select * from tb_test where 1=1  and _id=123  and username=34 
select * from tb_test where 1=1  and _id=123  and username like '%test1%' 
select * from tb_test where 1=1  and username in (test1,test2,test3,test4) 

目录
相关文章
|
24天前
|
Java
在 Java 中捕获和处理自定义异常的代码示例
本文提供了一个 Java 代码示例,展示了如何捕获和处理自定义异常。通过创建自定义异常类并使用 try-catch 语句,可以更灵活地处理程序中的错误情况。
48 1
|
24天前
|
Java
在 Java 中,如何自定义`NumberFormatException`异常
在Java中,自定义`NumberFormatException`异常可以通过继承`IllegalArgumentException`类并重写其构造方法来实现。自定义异常类可以添加额外的错误信息或行为,以便更精确地处理特定的数字格式转换错误。
30 1
|
26天前
|
JSON Java Apache
非常实用的Http应用框架,杜绝Java Http 接口对接繁琐编程
UniHttp 是一个声明式的 HTTP 接口对接框架,帮助开发者快速对接第三方 HTTP 接口。通过 @HttpApi 注解定义接口,使用 @GetHttpInterface 和 @PostHttpInterface 等注解配置请求方法和参数。支持自定义代理逻辑、全局请求参数、错误处理和连接池配置,提高代码的内聚性和可读性。
102 3
|
2天前
|
Java
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下
java实现从HDFS上下载文件及文件夹的功能,以流形式输出,便于用户自定义保存任何路径下
54 34
|
1月前
|
人工智能 前端开发 Java
基于开源框架Spring AI Alibaba快速构建Java应用
本文旨在帮助开发者快速掌握并应用 Spring AI Alibaba,提升基于 Java 的大模型应用开发效率和安全性。
基于开源框架Spring AI Alibaba快速构建Java应用
|
28天前
|
SQL Java 数据库连接
从理论到实践:Hibernate与JPA在Java项目中的实际应用
本文介绍了Java持久层框架Hibernate和JPA的基本概念及其在具体项目中的应用。通过一个在线书店系统的实例,展示了如何使用@Entity注解定义实体类、通过Spring Data JPA定义仓库接口、在服务层调用方法进行数据库操作,以及使用JPQL编写自定义查询和管理事务。这些技术不仅简化了数据库操作,还显著提升了开发效率。
37 3
|
1月前
|
Java 开发者 Spring
[Java]自定义注解
本文介绍了Java中的四个元注解(@Target、@Retention、@Documented、@Inherited)及其使用方法,并详细讲解了自定义注解的定义和使用细节。文章还提到了Spring框架中的@AliasFor注解,通过示例帮助读者更好地理解和应用这些注解。文中强调了注解的生命周期、继承性和文档化特性,适合初学者和进阶开发者参考。
52 14
|
1月前
|
前端开发 Java
[Java]讲解@CallerSensitive注解
本文介绍了 `@CallerSensitive` 注解及其作用,通过 `Reflection.getCallerClass()` 方法返回调用方的 Class 对象。文章还详细解释了如何通过配置 VM Options 使自定义类被启动类加载器加载,以识别该注解。涉及的 VM Options 包括 `-Xbootclasspath`、`-Xbootclasspath/a` 和 `-Xbootclasspath/p`。最后,推荐了几篇关于 ClassLoader 的详细文章,供读者进一步学习。
33 12
|
1月前
|
SQL 监控 Java
技术前沿:Java连接池技术的最新发展与应用
本文探讨了Java连接池技术的最新发展与应用,包括高性能与低延迟、智能化管理和监控、扩展性与兼容性等方面。同时,结合最佳实践,介绍了如何选择合适的连接池库、合理配置参数、使用监控工具及优化数据库操作,为开发者提供了一份详尽的技术指南。
33 7
|
1月前
|
SQL Java 数据库连接
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率。本文介绍了连接池的工作原理、优势及实现方法,并提供了HikariCP的示例代码。
47 3