模拟Hibernate底层生成SQL语句(反射机制)

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+")";
	}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值