使用子线程查询数据库

package Link.Mysql;
import java.sql.*;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;

public class QueryDataThread {
    private static final String DB_URL = "jdbc:mysql://localhost/en_chi_dict";
    private static final String USER = "root";
    private static final String PASS = "admin";

    public static void main(String[] args) {
        Thread queryThread = new Thread(new QueryDataRunnable());
        queryThread.start();
    }

    static class QueryDataRunnable implements Runnable {
        @Override
        public void run() {
            try (Connection conn = DriverManager.getConnection(DB_URL, USER, PASS);
                 Statement stmt = conn.createStatement()) {

                String sql = "SELECT * FROM dict_info";

                ResultSet rs = stmt.executeQuery(sql);

                List<DictInfo> dictInfoList = new ArrayList<>();

                while (rs.next()) {
                    int id = rs.getInt("Id");
                    String engName = rs.getString("eng_name");
                    String chiVal = rs.getString("chi_val");
                    String lastUsedTime = rs.getString("last_used_time");
                    int usedTimes = rs.getInt("used_times");
                    String createdTime = rs.getString("created_time");
                    int priority = rs.getInt("priority");

                    dictInfoList.add(new DictInfo(id, engName, chiVal, lastUsedTime, usedTimes, createdTime, priority));
                }

                for (DictInfo dictInfo : dictInfoList) {
                    int id = dictInfo.getId();

                    // 更新last_used_time字段
                    String timeStamp = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date());
                    String updateLastUsedTimeSql = "UPDATE dict_info SET last_used_time = '" + timeStamp + "' WHERE Id = " + id;
                    stmt.executeUpdate(updateLastUsedTimeSql);

                    // 更新used_times字段
                    int newUsedTimes = dictInfo.getUsedTimes() + 1;
                    String updateUsedTimesSql = "UPDATE dict_info SET used_times = " + newUsedTimes + " WHERE Id = " + id;
                    stmt.executeUpdate(updateUsedTimesSql);

                    System.out.println("Id: " + id);
                    System.out.println("English Name: " + dictInfo.getEngName());
                    System.out.println("Chinese Value: " + dictInfo.getChiVal());
                    System.out.println("Last Used Time: " + timeStamp);
                    System.out.println("Used Times: " + newUsedTimes);
                    System.out.println("Created Time: " + dictInfo.getCreatedTime());
                    System.out.println("Priority: " + dictInfo.getPriority());
                    System.out.println("---------------------");
                }
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }

    static class DictInfo {
        private int id;
        private String engName;
        private String chiVal;
        private String lastUsedTime;
        private int usedTimes;
        private String createdTime;
        private int priority;

        public DictInfo(int id, String engName, String chiVal, String lastUsedTime, int usedTimes, String createdTime, int priority) {
            this.id = id;
            this.engName = engName;
            this.chiVal = chiVal;
            this.lastUsedTime = lastUsedTime;
            this.usedTimes = usedTimes;
            this.createdTime = createdTime;
            this.priority = priority;
        }

        public int getId() {
            return id;
        }

        public String getEngName() {
            return engName;
        }

        public String getChiVal() {
            return chiVal;
        }

        public String getLastUsedTime() {
            return lastUsedTime;
        }

        public int getUsedTimes() {
            return usedTimes;
        }

        public String getCreatedTime() {
            return createdTime;
        }

        public int getPriority() {
            return priority;
        }
    }
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值