java注解,通过反射解析注解,模仿hibernate,获取sql语句。
常用注解:

自定义注解,标准格式:
1,target:注解作用域
2,Retention:声明周期





运行子类继承,但是子类继承只能作用到类注解,字段注解,是继承不了的。


使用注解:通过下面这种方式,为注解的成员赋值,使用的时候会通过成员名,找到这些值,去使用这些值。

如果注解只有一共成员,该成员必须命名为value,这样使用注解的时候方便:如:@注解(“值1”),相当于@注解(value=“值1”);

解析注解:
解析注解主要用到反射的方式,在下面的例子中可以看到。
主要代码如下:
//1,获取到class
Class c=f.getClass();
//2,获取到table的名字
boolean exists=c.isAnnotationPresent(Table.class);//判断该类Filete是否是包含注解Table
if(!exists)
{
return null;
}
Table t=(Table) c.getAnnotation(Table.class);//取出Filete这个类的Table注解
String tableName=t.value();//获取该注解的值

使用注解模仿hibernate获取sql的方法。
1,定义两个注解,Table和column
package com.Annotation; 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 com.Annotation; 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,定义一个数据库模型类:并分别在类名和字段名上加上注解,分别跟表名和字段名关联
package com.Annotation;
@Table("user")
public class Filter {
@Column("id")
private int id;
@Column("user_Name")
private String userName;
@Column("age")
private int age;
@Column("city")
private String city;
@Column("email")
private String email;
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 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;
}
}
3,通过set字段值,来定义查询条件,定义一共querey方法,同注解,反射获取sql。
package com.Annotation; import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method; public class Test { public static void main(String[] args) { Filter f1=new Filter();
f1.setAge(10);//查询id为10的用户 Filter f2=new Filter();
f2.setCity("大连");//查询城市为大连的用户 Filter f3=new Filter();
f3.setCity("liu@sina.com,zh@sina.com,8888@163.com");
//查询邮箱为上面的用户 String sql1=query(f1);
String sql2=query(f2);
String sql3=query(f3);
System.out.println(sql1);
System.out.println(sql2);
System.out.println(sql3);
}
private static String query(Filter f)
{
StringBuffer sb=new StringBuffer();
//1,获取到class
Class c=f.getClass();
//2,获取到table的名字
boolean exists=c.isAnnotationPresent(Table.class);//判断该类Filete是否是包含注解Table
if(!exists)
{
return null;
}
Table t=(Table) c.getAnnotation(Table.class);//取出Filete这个类的Table注解
String tableName=t.value();//获取该注解的值
sb.append(" select * from ").append(tableName).append("where 1=1");
//3,遍历所有字段
Field[] fArray=c.getDeclaredFields();
for(Field field:fArray)
{
//4,处理每个字段对应的sql
//4,1,拿到字段名
boolean fExis=field.isAnnotationPresent(Column.class);
if(!exists)
{
continue;
}
Column column=field.getAnnotation(Column.class);//获取该字段上的column注解
String columnName=column.value(); //4,2,拿到字段的值
String filedName=field.getName();
String getMethoudName="get"+filedName.substring(0,1).toUpperCase()+
filedName.substring(1);
Object fieldValue = null;//为了让各种类型的返回值都能接收,定义Object类型
try {
Method getMethod=c.getMethod(getMethoudName);
fieldValue=getMethod.invoke(f);//调用f的对应字段的get方法
} catch (Exception e) {
e.printStackTrace();
} //4,3,拼装sql
if(fieldValue==null||
(fieldValue instanceof Integer && (Integer)fieldValue==0))
{
continue;
}
sb.append(" and ").append(filedName);
if(fieldValue instanceof String) //如果字符串是Int类型,加上单引号
{
if(((String) fieldValue).contains(",")) //包含,,表示是子查询
{
String []values=((String) fieldValue).split(",");
sb.append("in("); for(String v:values)
{
sb.append("'").append(v).append("'").append(",");
}
sb.deleteCharAt(sb.length()-1);//去掉最后一个逗号
sb.append(")");
}
else //否则是普通查询
{
sb.append("=").append("'").append(fieldValue).append("'");
}
}
else if(fieldValue instanceof Integer)
{
sb.append("=").append(fieldValue);
}
}
return sb.toString();
}
}
运行结果:

java注解,通过反射解析注解,模仿hibernate,获取sql语句。的更多相关文章
- 【java--反射】注解(反射解析注解+注解应用)
创建实体类 package cn.com.codingce.iocannotation; /** * @Author: Jiangjun * @Date: 2019/10/7 9:54 */ publ ...
- java微信开发API解析(二)-获取消息和回复消息
java微信开发API解析(二)-获取消息和回复消息 说明 * 本演示样例依据微信开发文档:http://mp.weixin.qq.com/wiki/home/index.html最新版(4/3/20 ...
- Hibernate执行sql语句
Hibernate执行sql语句:BasicServiceImpl basicServiceImpl = new BasicServiceImpl();String hql = "selec ...
- 在hibernate中用sql语句
在hibernate中用sql语句,语句是createSQLquery 查出来的是,一列或者多列的数据,要将其转化为对象,有两种方式, 对于已经被hibernate所管理的实体类,在后面加.adden ...
- Java基础之反射、注解、代理
反射 笔者对反射的理解就是解剖class文件,来进行一系列操作. Class类 获取Class类实例的三种方式: 类名.class 对象.getClass() static Class forName ...
- Java中的反射和注解
前言 在Java中,反射机制和注解机制一直是一个很重要的概念,那么他们其中的原理是怎么样呢,我们不仅仅需要会使用,更要知其然而之所以然. 目录 反射机制 反射如何使用 注解定义 注解机制原理 注解如何 ...
- 【Java基础】反射和注解
前言 在Java中,反射机制和注解机制一直是一个很重要的概念,那么他们其中的原理是怎么样呢,我们不仅仅需要会使用,更要知其然而之所以然. 目录 反射机制 反射如何使用 注解定义 注解机制原理 注解如何 ...
- JAVA高级特性反射和注解
反射: 枚举反射泛型注解.html34.3 KB 反射, 主要是指通过类加载, 动态的访问, 检测和修改类本身状态或行为的一种能力, 并能根据自身行为的状态和结果, 调整或修改应用所描述行为的状态和相 ...
- Java高级篇反射和注解
反射是什么? 反射的作用?能带来什么好处? 反射的使用? 注解的使用? 注解和反射配合实战...
随机推荐
- bzoj1798 维护序列
Description 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2 ...
- 51nod 1040 最大公约数之和 欧拉函数
1040 最大公约数之和 题目连接: https://www.51nod.com/onlineJudge/questionCode.html#!problemId=1040 Description 给 ...
- 对于GTPv1协议头部的解析
参考ETSI EN 301 347 GTP是GPRS Tunnelling Protocol 的简称.GTP分为GTPv0(已经淘汰),GTPv1 和GTPv2.下面,介绍的是GTPv1. GTPv1 ...
- 测试用例设计——WEB通用测试用例(转)
http://qa.blog.163.com/blog/static/190147002201111332029404/
- asp.net 链接数据库ADO.NET
web.config <configuration> <connectionStrings> <add name="constr" connectio ...
- ASP.NET数据库连接字符串总结
一.使用OleDbConnection对象连接OLE DB数据源 1.连接Access 数据库 Access 2000: “provider=Microsoft.Jet.Oledb.3.5;Data ...
- springmvc整合slf4j、log4j记录文本日志
一.配置pom.xml 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 3 ...
- 惠普HP compaq康柏系列 CQ40笔记本电脑拆机除尘
工具:两用螺丝刀(一字口的拆CPU,十字口的拆其它所有螺丝) 散热硅胶和CPU上的散热贴 正面照(A面) 反面照(D面) 第一步:拆掉电池,不要忘记了红圈这里的两颗螺丝.共6颗小螺丝. 第二步: ...
- Shell编程(脚本)的经常使用命令和语句
一些经常使用的Shell编程(脚本)命令和语句,能够满足一般需求. 接收到的命令參数: 參数个数: $# 參数值: 命令本身:$0 第一个參数:$1 第二个參数:$2 -- 退出命令: exit ec ...
- wsgi & cgi的一些概念解释
可以看这里 https://www.zhihu.com/question/19998865 如何理解 CGI, WSGI?修改 写补充说明 举报 添加评论 分享 • 邀请回答 默认排序 按时间排序 1 ...