jdbc查询大量数据内存溢出的解决方法

当使用jdbc从mysql中查询大量数据时,有可能会导致内存溢出。为了避免这种情况的发生可以对数据库进行分页查询。

 

public static void main(String[] args){ 
    String url = "jdbc:mysql://localhost:3306/test"; 
    String username = "username"; 
    String password = "password";

    int data_num = 0; 
    try { 
        Class.forName("com.mysql.jdbc.Driver"); 
        Connection con = DriverManager.getConnection(url, username, 
                password);

        String sql = "SELECT ID,NAME FROM table_name limit ?,?"; 
        PreparedStatement pst = con.prepareStatement(sql); 

        int pageSize = 10000; 
        int pageId = 0; 
        do { 
            pst.setInt(1, pageId * pageSize); 
            pst.setInt(2, pageSize); 
            ResultSet rs = pst.executeQuery();

            boolean isEmpty = true; 
            while (rs.next()) { 
                 isEmpty = false; 
                 id = rs.getLong(1); 
                 name = rs.getString(2); 
                 data_num++; 
            } 
            if (isEmpty) { 
                break; 
            } 
            pageId++; 
        } while (true); 
        con.close(); 
    } catch (SQLException se) { 
        se.printStackTrace(); 
    }

利用上述的代码可以对数据库表进行遍历处理。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值