java实现修改字段记录

该文展示了如何使用Java注解和反射机制创建一个工具类,用于比较两个对象实例的特定字段值。在实体类中,定义了一个名为@Compare的注解来标记需要比较的字段。在ObjectComparator工具类中,遍历对象的字段,查找带有@Compare注解的字段并比较它们的新旧值,当值不相等时,记录差异。测试用例演示了如何使用这个工具类来找出两个UserInfo对象之间的变化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.写个注解

@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.FIELD)
public @interface Compare {
    String value();
}

2.工具类

public class ObjectComparator {

    public static List<Map<String, String>> compare(Object oldObj, Object newObj) {

        List<Map<String,String>> resultList= new ArrayList<>();
        try {
            // 获取所有字段
            Field[] fields = oldObj.getClass().getDeclaredFields();

            // 遍历所有字段
            for (Field field : fields) {
                // 如果字段被 @Compare 注解标注
                if (field.isAnnotationPresent(Compare.class)) {
                    // 获取字段的中文名
                    String fieldName = field.getAnnotation(Compare.class).value();

                    // 设置字段可访问
                    field.setAccessible(true);

                    // 获取字段的旧值和新值
                    Object oldValue = field.get(oldObj);
                    Object newValue = field.get(newObj);

                    // 如果值不相等
                    if (!Objects.equals(oldValue, newValue)) {
                        Map<String, String> result = new HashMap<>(16);
                        // 将字段名和值添加到结果中
                        result.put(fieldName, "旧值:" + oldValue + ",新值:" + newValue);
                        resultList.add(result);
                    }
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        }

        return resultList;
    }

3.实体类

@Data
public class UserInfo {

    @Compare("姓名")
    private String name;

    @Compare("性别")
    private String sex;
}

4.测试

public class Test {

    public static void main(String[] args) {

       UserInfo oldUser = new UserInfo();
       oldUser.setName("张三");
       oldUser.setSex("男");

       UserInfo newUser = new UserInfo();
       newUser.setName("李四");
       newUser.setSex("女");
       List<Map<String, String>> changes = ObjectComparator.compare(oldUser, newUser);
        for(int i=0;i<changes.size();i++){
            Map<String,String> map = changes.get(i);
            for (Map.Entry<String, String> entry : map.entrySet()) {
                System.out.println(entry.getKey() + ":" + entry.getValue());
            }
        }

    }
}

5.结果
在这里插入图片描述

### Java批量更新MySQL单个字段Java应用程序中执行对MySQL数据库内单一字段的批量修改操作时,推荐采用PreparedStatement来提高效率并增强安全性。通过设置自动批处理模式可以显著减少网络往返次数从而提升性能。 #### 使用PreparedStatement进行批量更新 为了高效地完成这项任务,应该创建一个`PreparedStatement`对象,并利用其内置方法开启批处理功能。对于每一个待更新记录,在预编译SQL语句上设定相应参数值之后调用addBatch()函数加入到当前批次;当累积一定数量或是到达数据集末端时,则可通过executeBatch()一次性提交所有变更请求给服务器端处理[^1]。 下面是一个具体的例子展示怎样使用JDBC API中的PreparedStatement来进行批量更新: ```java import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; public class BatchUpdateExample { public static void main(String[] args) throws Exception { String url = "jdbc:mysql://localhost:3306/testdb"; String user = "root"; String password = ""; try (Connection conn = DriverManager.getConnection(url, user, password)) { // 关闭自动提交以便手动控制事务边界 conn.setAutoCommit(false); String sql = "UPDATE employees SET salary = ? WHERE id = ?"; PreparedStatement pstmt = conn.prepareStatement(sql); int batchSize = 20; // 设置每一批次大小 for (int i = 1; i <= 100; ++i) { // 假设有100条记录需要被更新 double newSalary = calculateNewSalary(i); // 计算新的工资数额 pstmt.setDouble(1, newSalary); pstmt.setInt(2, i); pstmt.addBatch(); if (i % batchSize == 0 || i == 100) { // 当达到指定批次大小或最后一项时执行批处理 pstmt.executeBatch(); conn.commit(); // 提交更改 // 清除之前的命令以准备下一轮循环 pstmt.clearBatch(); System.out.println("Processed batch of size:" + Math.min(batchSize,i)); } } pstmt.close(); } catch (Exception e) { throw new RuntimeException(e.getMessage()); } } private static double calculateNewSalary(int employeeId){ // 这里只是一个简单的模拟计算逻辑 return employeeId * 1000.0d; } } ``` 此代码片段展示了如何连接至MySQL数据库并通过PreparedStatement安全有效地实施批量更新操作。注意这里关闭了默认的自动提交机制(`conn.setAutoCommit(false)`),这允许程序能够更好地管理自己的事务范围,确保只有成功完成了整个批处理过程才会真正影响到实际的数据表结构[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值