从MySQL数据库中导出数据

本文介绍了一种使用Java从MySQL数据库中读取特定表的数据,并将这些数据存储到本地文件的方法。通过预编译SQL语句提高了安全性,同时根据文件是否存在采取新建或追加的策略来写入数据。

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

从MySQL数据库中导出数据


package lianjie;



import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileWriter;
import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
 
/**
 * java读取数据库内容并存放到文件中
 * 
 * @author wang
 *
 */
public class JavaToSQLTest {
static int count;
public static void main(String[] args) {
PrintWriter pw = null;
        FileWriter fw = null; 
Connection conn = null;
Statement st=null;
String guanjian;
try {
conn = Dbutil.getConnection();
   st=conn.createStatement();
            // 创建预编译SQL对象
            PreparedStatement ps = conn
                    .prepareStatement("select guanjian from keyword");
            // 执行SQL,获取结果集rs
            ResultSet rs = ps.executeQuery();
            // 处理结果集
            while (rs.next()) {
            guanjian = rs.getString("guanjian");
                String filename = "aa" + ".txt";
                // 关联文件
                File file = new File(filename);
                if(!file.exists()){
                    // 判断文件不存在就new新文件,写数据
                    try {
                        file.createNewFile();
                        // java IO流和文件关联
                        pw = new PrintWriter(file);
                        pw.print(guanjian);
                        pw.println();
                        pw.flush();
                    } catch (IOException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                    }
                     
                }else{
                    // 判断文件存在,就以FileWriter文件追加的方式写文件
                    try {
                        fw = new FileWriter(filename,true);
                        System.out.println();
                        fw.write("\n"+guanjian);
                        fw.flush();
                    } catch (IOException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                    }
                }
            }
 
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
            System.out.println("数据库连接错误");
            System.exit(1);
        } finally {
            if (conn != null) {
                try {
                    // 关闭数据库连接
                    conn.close();
                } catch (SQLException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }
            if (pw != null) {
                // 关闭IO流
                pw.close();
            }
            if(fw != null){
                try {
                    fw.close();
                } catch (IOException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }
        }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值