使用子线程查询数据库

该文章详细描述了一个Java程序,通过Mysql连接执行SQL查询,获取dict_info表中的数据,并在运行时更新last_used_time和used_times字段。程序中创建了DictInfo类来存储查询结果。
摘要由CSDN通过智能技术生成
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
    评论
Qt多线程是一种在Qt框架下实现多线程并发的技术,它允许我们同时处理多个任务,提高程序的执行效率。而数据库链接池是一种管理数据库连接的技术,它可以提前创建一定数量的数据库连接并进行管理,以提升数据访问的效率。 在使用Qt多线程进行数据库操作时,可以通过创建线程池来实现对数据库链接池的管理。首先,在主线程中创建一个数据库链接池对象,在该对象中创建一定数量的数据库连接,并将这些连接存放在一个容器中(比如使用队列)。然后,在需要进行数据库操作的线程中,可以通过从数据库链接池中获取一个数据库连接来执行相应的操作。 具体来说,当一个线程需要进行数据库操作时,首先从数据库链接池中获取一个可用的数据库连接。在执行数据库操作之前,需要保证其他线程不能同时占用同一个数据库连接,可以使用互斥锁等机制进行线程同步。当数据库操作完成后,将数据库连接放回数据库链接池中,以供其他线程使用。 通过使用Qt多线程数据库链接池,可以充分利用多核处理器的并发能力,提高程序的响应速度和吞吐量。同时,使用数据库链接池可以避免频繁创建和销毁数据库连接的开销,减少数据库资源的浪费,并降低了数据库服务器的负载。 总之,Qt多线程数据库链接池的结合能够提高程序的并发处理能力和数据库访问效率,适用于需要高并发访问数据库的场景,并能有效提升程序的性能。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值