在数据库操作中通常有如下的插入语句:insert into user (id,name,age) values (‘1‘,‘张三‘,‘18‘),使用反射完成 SQL 的拼接。 Student stud

题目:在数据库操作中通常有如下的插入语句:

一、题目描述:

  在数据库操作中通常有如下的插入语句:insert into user (id,name,age) values (‘1’,‘张三’,‘18’),使用反射完成 SQL 的拼接。Student student = new Student(1, “张三”, 18);System.out.println(getSQL(user));

二、核心代码如下:

package homework10.homework1027;

import java.lang.reflect.Field;

/**
 * 在数据库操作中通常有如下的插入语句:insert into user (id,name,age) values ('1','张三','18'),
 * 使用反射完成 SQL 的拼接。
 * Student student = new Student(1, "张三", 18);
 * System.out.println(getSQL(user));
 */
public class Demo01 {
    public static void main(String[] args) throws IllegalAccessException {
        Student s = new Student(1, "张三", 18);//实例化对象
        StringBuffer sql = getSQL(s);//调用getSQL()方法
        System.out.println(sql);
    }
	//getSQL()方法
    public static StringBuffer getSQL(Object o) throws IllegalAccessException {
        Class clazz = o.getClass();//利用反射获取类的属性和方法等
        StringBuffer stringBuffer = new StringBuffer("insert into ");
        stringBuffer.append(clazz.getSimpleName() + " (");
        Field[] fields = clazz.getDeclaredFields();
        for (Field field : fields) {
            field.setAccessible(true);//暴力反射,获取类的属性
            stringBuffer.append(field.getName() + ",");
        }
        stringBuffer.deleteCharAt(stringBuffer.length() - 1);//将最后一个位置的字符删除
        stringBuffer.append(") values (");//添加内容
        for (Field field : fields) {
            Object o1 = field.get(o);
            stringBuffer.append("'" + o1 + "',");
        }
        stringBuffer.deleteCharAt(stringBuffer.length() - 1);//将最后一个位置的字符删除
        stringBuffer.append(");");
        return stringBuffer;
    }
}
//建一个学生类
class Student {
    private Integer id;//用户ID
    private String name;//用户姓名
    private Integer age;//用户年龄

    public Student() {
    }

    public Student(Integer id, String name, Integer age) {
        this.id = id;
        this.name = name;
        this.age = age;
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }
}

三、代码运行结果如下:

在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

faramita_of_mine

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值