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

1.定义 Table 注解

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

2.定义 Column 注解

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

3.定义使用注解的实体

  1. package test;
  2. @Table("tb_test")
  3. public class TestDto {
  4. @Deprecated
  5. private String tt;
  6. @Column("_id")
  7. private String id;
  8. @Column("username")
  9. private String name;
  10. public TestDto(String id, String name) {
  11. super();
  12. this.id = id;
  13. this.name = name;
  14. }
  15. public String getId() {
  16. return id;
  17. }
  18. public void setId(String id) {
  19. this.id = id;
  20. }
  21. public String getName() {
  22. return name;
  23. }
  24. public void setName(String name) {
  25. this.name = name;
  26. }
  27. }

4.测试注解

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

测试结果:

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)

注解:java 自定义注解应用实例的更多相关文章

  1. java自定义注解知识实例及SSH框架下,拦截器中无法获得java注解属性值的问题

    一.java自定义注解相关知识 注解这东西是java语言本身就带有的功能特点,于struts,hibernate,spring这三个框架无关.使用得当特别方便.基于注解的xml文件配置方式也受到人们的 ...

  2. Java 自定义注解与注解解析实例

    在学习Java之后会遇到很多的注解,有加载JavaBean的注解:@Component,@Service,@Controller:有获取配置文件中数值的注解@Value:有获取Http请求的数据的注解 ...

  3. java自定义注解类

    一.前言 今天阅读帆哥代码的时候,看到了之前没有见过的新东西, 比如java自定义注解类,如何获取注解,如何反射内部类,this$0是什么意思? 于是乎,学习并整理了一下. 二.代码示例 import ...

  4. Java自定义注解开发

    一.背景 最近在自己搞一个项目时,遇到可需要开发自定义注解的需求,对于没有怎么关注这些java新特性的来说,比较尴尬,索性就拿出一些时间,来进行研究下自定义注解开发的步骤以及使用方式.今天在这里记下, ...

  5. java自定义注解注解方法、类、属性等等【转】

    http://anole1982.iteye.com/blog/1450421 http://www.open-open.com/doc/view/51fe76de67214563b20b385320 ...

  6. Java自定义注解和运行时靠反射获取注解

    转载:http://blog.csdn.net/bao19901210/article/details/17201173/ java自定义注解 Java注解是附加在代码中的一些元信息,用于一些工具在编 ...

  7. Java注解-元数据、注解分类、内置注解和自定义注解|乐字节

    大家好,我是乐字节的小乐,上次说过了Java多态的6大特性|乐字节,接下来我们来看看Java编程里的注解. Java注解有以下几个知识点: 元数据 注解的分类 内置注解 自定义注解 注解处理器 Ser ...

  8. Java自定义注解Annotation的使用

    从 jdk5开始,Java增加了对元数据的支持,也就是Annotation,Annotation其实就是对代码的一种特殊标记,这些标记可以在编译,类加载和运行时被读取,并执行相应的处理.当然刚刚说了, ...

  9. java自定义注解实现前后台参数校验

    2016.07.26 qq:992591601,欢迎交流 首先介绍些基本概念: Annotations(also known as metadata)provide a formalized way ...

  10. Java自定义注解的实现

    Java自定义注解的实现,总共三步(eg.@RandomlyThrowsException): 1.首先编写一个自定义注解@RandomlyThrowsException package com.gi ...

随机推荐

  1. new的越界访问

    今天敲代码的时候发现了一个BUG和大家分享一下,希望大家下次不要犯和我一样的错误. 如果犯了和我一样的错,也能知道自己错在哪里!   <(^-^)> 函数如下:(斐波那契数列的实现) lo ...

  2. my.cnf重要配置参数说明

    不同存储引擎中关键参数优化 MyISAM存储引擎 MyISAM存储引擎适用于读多写少,对读性能要求比较高的系统 官方文档:http://dev.mysql.com/doc/refman/5.6/en/ ...

  3. Spring Cloud之Eureka自我保护环境搭建

    Eureka详解 服务消费者模式 获取服务 消费者启动的时候,使用服务别名,会发送一个rest请求到服务注册中心获取对应的服务信息,让后会缓存到本地jvm客户端中,同时客户端每隔30秒从服务器上更新一 ...

  4. wampserver2 配置ssl 经过验证 可用

    本文原地址 http://blog.csdn.net/taosst/article/details/2182966 http://forum.wampserver.com/read.php?2,329 ...

  5. 2.微信小程序-B站:需要先知道这些

    文件结构 小程序包含一个描述整体程序的 app 和多个描述各自页面的 page.一个小程序主体部分由三个文件组成,必须放在项目的根目录,如下: 文件 必须 作用 app.js 是 小程序逻辑 app. ...

  6. UOJ136 开学前的作文

    描述 红包是一个萌萌的男孩子. 红包由于 NOI 惨挂,直到前不久依然无心写作业.如今快开学了,他决定好好完成作业. 对于可以交电子稿的作文,红包有特殊的完成技巧,大致流程是依次选中一段内容→按下 C ...

  7. 常用连续型分布介绍及R语言实现

    常用连续型分布介绍及R语言实现 R的极客理想系列文章,涵盖了R的思想,使用,工具,创新等的一系列要点,以我个人的学习和体验去诠释R的强大. R语言作为统计学一门语言,一直在小众领域闪耀着光芒.直到大数 ...

  8. jQuery应用之eraser.js使用,实现擦除、刮刮卡效果

    jquery.eraser是一款使用鼠标或触摸的动作来擦除画布显示真正图片的插件.jquery.eraser插件的原理是用一个画布遮住图片,然后根据触摸或鼠标输入来擦除画布显示图片,您可以在参数中指定 ...

  9. php数据结构课程---1、数据结构基础介绍(程序是什么)

    php数据结构课程---1.数据结构基础介绍(程序是什么) 一.总结 一句话总结: 程序=数据结构+算法 设计好数据结构,程序就等于成功了一半. 数据结构是程序设计的基石. 1.数据的逻辑结构和物理结 ...

  10. 分享知识-快乐自己:大数据(hadoop)环境搭建

    大数据 hadoop 环境搭建: 一):大数据(hadoop)初始化环境搭建 二):大数据(hadoop)环境搭建 三):运行wordcount案例 四):揭秘HDFS 五):揭秘MapReduce ...