利用java发射 生产对象的sql插入语句

import java.lang.reflect.Field;
import java.lang.reflect.Method;

/**
 * 这是用java反射来实现对对象的属性,方法,类名的取值。再组成一条万能的insert 语句。
 * @author 小高
 */
public class Test2 {

	public static void main(String[] args) throws Exception {
		Test2 t=new Test2();
		Student stu=new Student();  //可以对任意对象操作
		stu.setName("小高");
		stu.setAge(20);
		stu.setId(11);
		
	    String sql=t.createInsertSql(stu);
	    System.out.println(sql);
	}
	
    private String createInsertSql(Object obj) throws Exception {
    	Class cls=obj.getClass();
    	String sql="insert into "+cls.getSimpleName()+" (";  //类名
    	Field fields[]=cls.getDeclaredFields();
    	String columnName=""; //列名
    	String columnValue=""; //列值
    	Object objs[]=new Object[fields.length];  //多少个字段就多少个值
    	for (int i = 0; i < fields.length; i++) {
    		String fieldName=fields[i].getName();  //获得字段
			String fieldMethodOfget=fieldName.substring(0, 1).toUpperCase()+fieldName.substring(1, fieldName.length());
			Method methodofget = cls.getMethod("get"+fieldMethodOfget, null);
			Object value=methodofget.invoke(obj, null); //字段的值	
			if(value!=null){  //判断是否设置值
				columnName+=","+fieldName;
				if(value.getClass().getSimpleName().equals("String")){
					columnValue+=",'"+value+"'";
				}else{
					columnValue+=","+value;
				}
			}
		}
    	columnName=columnName.substring(1, columnName.length());
    	sql+=columnName+") values (";
    	columnValue=columnValue.substring(1, columnValue.length());
    	sql+=columnValue +")";
    	return sql;
	}
}
输出的结果如图所示:
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值