java mysql导入txt文件_java 读取文件夹并存入数据库(TXT)

package com.zte.m2m.dao.upload;

import java.io.BufferedReader;

import java.io.File;

import java.io.FileInputStream;

import java.io.FileOutputStream;

import java.io.IOException;

import java.io.InputStreamReader;

import java.io.OutputStream;

import org.apache.commons.net.ftp.FTPClient;

import org.apache.commons.net.ftp.FTPFile;

import org.apache.commons.net.ftp.FTPReply;

import java.sql.CallableStatement;

import java.sql.Connection;

import oracle.sql.ARRAY;

import com.zte.ismp.common.dao.CommonDao;

import util.DBHandle;

/**

*

 
 

* 描述信息:数据批量汇入

*

* @author xieyuchun

* @version 1.0

*

* 完成日期:2014-06-13

*

*/

public class DataBatchUploadDao extends CommonDao {

/*

* 文件入库

*

* filePath:文件夹绝对路径

*/

public void upload (String filePath){

System.out.println("文件入库");

DBHandle handler = null;

Connection con = null;

CallableStatement cstmt = null;

try{

//数据库连接对象

handler = this.getHandler();

//获取数据库连接

con = handler.getCon();

if(1 == 1){

String encoding="GBK";

File folder = new File(filePath);

//folder.list() 获取文件夹下所有文件名

String[] fileArray = folder.list();

for (String fileName : fileArray) {

System.out.println(fileName);

File file = new File(filePath+"\\"+fileName);

fileName = fileName.substring(0, fileName.indexOf("."));

// //判断文件是否存在

if (file.isFile() && file.exists())

{

InputStreamReader read = new InputStreamReader(

new FileInputStream(file), encoding);

BufferedReader bufferedReader = new BufferedReader(read);

String lineTxt = null;

// 读取txt

while ((lineTxt = bufferedReader.readLine()) != null) {

System.out.println(lineTxt);

cstmt = con.prepareCall("{ call pro_forall_insert(?,?,?) }");

cstmt.setObject(1,fileName);

cstmt.setObject(2, lineTxt);

cstmt.setObject(3, ",");

cstmt.execute();

}

read.close();

System.out.println("文件入库完成");

} else {

System.out.println("找不到指定的文件");

}

}

}

} catch (Exception e) {

throw new RuntimeException(e);

} finally {

if (null != handler) {

handler.release();

}

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用Java中的JDBC API来连接MySQL数据库并查询数据,然后使用Java IO流将数据写入到TXT文件中。具体步骤如下: 1. 导入MySQL JDBC驱动程序 在开始编写Java程序之前,需要先下载并导入MySQL JDBC驱动程序。可以从MySQL官方网站下载最新版本的JDBC驱动程序,并将其添加到Java项目的类路径中。 2. 连接MySQL数据库 使用JDBC API中提供的DriverManager类和Connection接口来连接MySQL数据库。需要提供MySQL数据库的URL、用户名和密码等信息。代码示例如下: ``` String url = "jdbc:mysql://localhost:3306/mydatabase"; String user = "root"; String password = "123456"; Connection conn = DriverManager.getConnection(url, user, password); ``` 3. 查询数据 连接成功后,可以使用Java的Statement或PreparedStatement对象来执行SQL查询语句,获取MySQL数据库中的数据。代码示例如下: ``` Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SELECT * FROM mytable"); while (rs.next()) { // 处理查询结果 } ``` 4. 写入TXT文件 使用Java IO流中的FileWriter和BufferedWriter类将查询结果写入到TXT文件中。代码示例如下: ``` File file = new File("data.txt"); FileWriter fw = new FileWriter(file); BufferedWriter bw = new BufferedWriter(fw); while (rs.next()) { String data = rs.getString("data"); bw.write(data); bw.newLine(); } bw.close(); fw.close(); ``` 完整的Java代码示例: ``` import java.io.BufferedWriter; import java.io.File; import java.io.FileWriter; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; public class MySQLToTXT { public static void main(String[] args) throws Exception { String url = "jdbc:mysql://localhost:3306/mydatabase"; String user = "root"; String password = "123456"; Connection conn = DriverManager.getConnection(url, user, password); Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SELECT * FROM mytable"); File file = new File("data.txt"); FileWriter fw = new FileWriter(file); BufferedWriter bw = new BufferedWriter(fw); while (rs.next()) { String data = rs.getString("data"); bw.write(data); bw.newLine(); } bw.close(); fw.close(); rs.close(); stmt.close(); conn.close(); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值