package com.factory.dao.imp;
import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Set;
import com.factory.dao.UsersDao;
public class UsersDaoImp implements UsersDao{
@Override
public String getSQL(Object object) {
String classAllName = object.getClass().getName();//获取对象对应类全名,包括类所在的包
String className = object.getClass().getSimpleName();//只获取对象对应类名
String str = "";//初始化一个字符串,用于存生成SQL语句
try {
Class c = Class.forName(classAllName);//使用反射加载对象对应实体类
Method[] ms = c.getDeclaredMethods();//获取实体类中所有set与get方法,存入Method数组中
//创建HashMap对象,用于存储方法中截取出来的属性名以及方法对应的属性值,比如:getName方法截取出来name属性以及对应值
HashMap<String, String> mapPropertyNameAndValue = new HashMap<String, String>();
for (Method method : ms) {//遍历获取到的Method数组,存储的全是方法
String name = method.getName();//获取方法对应的方法名,如getName
//获取方法名是get开头的方法名,并且排除是getClass开头的方法名,每个类都有一个getClass方法,都是继承的Object超类的
if(name.startsWith("get") && !name.startsWith("getClass")){
Method m = c.getMethod(name);//获取方法名对应的方法的修饰符 返回值类型 方法名
String mStr = m.getName();//获取方法对应方法名
//截取获取到的方法名获得对应属性名,并且将属性名设置为全小写
String mGetPropertyName = mStr.substring(3,mStr.length()).toLowerCase();
String strGet = m.invoke(object, null).toString();//获取对应属性的值
mapPropertyNameAndValue.put(mGetPropertyName, strGet);//将获取到的属性名与之属性值存入HashMap
}
}
ArrayList<String> listPropertyName = new ArrayList<String>();//创建存储实体类属性的集合
Field[] filed = c.getDeclaredFields();//获取类的所有属性,包括属性的修饰符,类型,属性名。
for (Field field1 : filed) {
String propertyName = field1.getName();//获取属性名
listPropertyName.add(propertyName);
}
//遍历实体类属性集合
for (String propertyName : listPropertyName) {
Set set = mapPropertyNameAndValue.keySet();//创建set对象
Iterator iter = set.iterator();//通过set对象创建迭代器对象
while(iter.hasNext()){
String key = (String) iter.next();//获取HashMap中的一条属性名
if(propertyName.equals(key)){//当HashMap中的属性名与实体类的当前属性名相等时
String value = mapPropertyNameAndValue.get(key);//通过属性名获取对于属性值
String strGet = "'"+value+"'";//处理获取到的属性值
str += strGet+",";//拼接SQL中的values()中的值
break;
}
}
}
str = str.substring(0, str.length()-1);
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (NoSuchMethodException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SecurityException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalAccessException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalArgumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InvocationTargetException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return "insert into "+className+" values("+str+")";
}
}