时间:2021-07-01 10:21:17 帮助过:2人阅读
package com.guoxinet.o2o.annotation; @Table("tb_department") public class DepartMent { @Column("department_id") private int departmentId; @Column("name") private String name; public int getDepartmentId() { return departmentId; } public void setDepartmentId(int departmentId) { this.departmentId = departmentId; } public String getName() { return name; } public void setName(String name) { this.name = name; } }
package com.guoxinet.o2o.annotation; import java.lang.reflect.Field; import java.lang.reflect.Method; public class Client { public static void main(String[] args) { User user = new User(); user.setUserId(1); user.setEmail("3964412@qq.com,yafeng@yahu.com,lifeng@guoxinet.com"); getSql(user); DepartMent dm = new DepartMent(); dm.setDepartmentId(100); dm.setName("技术部"); getSql(dm); } public static String getSql(Object ob){ StringBuilder sb = new StringBuilder(); //获取class @SuppressWarnings("rawtypes") Class c = ob.getClass(); //获取table的名字 @SuppressWarnings("unchecked") boolean isExist = c.isAnnotationPresent(Table.class); if(!isExist){ return ""; } Table table = (Table)c.getAnnotation(Table.class); String tableName = table.value(); sb.append("select * from ").append(tableName).append(" where 1=1 "); //遍历属性 Field[] fArray =c.getDeclaredFields(); for(Field field: fArray){ boolean fisExist = field.isAnnotationPresent(Column.class); if(!fisExist){ continue; } Column column = (Column)field.getAnnotation(Column.class); //列名 String columnName = column.value(); //得到属性的值 String methodName = "get" +field.getName().substring(0,1).toUpperCase() + field.getName().substring(1); Object fieldValue = null; try { Method method = c.getMethod(methodName); fieldValue = method.invoke(ob); if(null == fieldValue || (fieldValue instanceof Integer && 0 == (Integer)fieldValue) ){ System.out.println(fieldValue); continue; } sb.append(" and ").append(columnName); if(fieldValue instanceof String){ if(((String) fieldValue).contains(",")){ String[] sArray = ((String) fieldValue).split(","); sb.append(" in ").append("("); for(String s : sArray){ sb.append("‘").append(s).append("‘,"); } sb.deleteCharAt(sb.length()-1); sb.append(")"); }else{ sb.append(" = "); sb.append("‘").append(fieldValue).append("‘"); } }else{ sb.append(" = ").append(fieldValue); } } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } } sb.append(";"); System.out.println(sb.toString()); return null; } }
注解学习实例(模拟hibernate,table,column注解,拼装SQL)
标签: