java如何从数据库读取数据并写入txt文件?

java如何从数据库读取数据并写入txt文件?,第1张

写Java程序时经常碰到要读如txt或写入txt文件的情况,但是由于要定义好多变量,经常记不住,每次都要查,特此整理一下,简单易用,方便好懂!

[java] view plain copy

package edu.thu.keyword.test  

  

import java.io.File  

import java.io.InputStreamReader  

import java.io.BufferedReader  

import java.io.BufferedWriter  

import java.io.FileInputStream  

import java.io.FileWriter  

  

public class cin_txt {  

    static void main(String args[]) {  

        try { // 防止文件建立或读取失败,用catch捕捉错误并打印,也可以throw  

  

            /* 读入TXT文件 */  

            String pathname = "D:\\twitter\\13_9_6\\dataset\\en\\input.txt" // 绝对路径或相对路径都可以,这里是绝对路径,写入文件时演示相对路径  

            File filename = new File(pathname) // 要读取以上路径的input。txt文件  

            InputStreamReader reader = new InputStreamReader(  

                    new FileInputStream(filename)) // 建立一个输入流对象reader  

            BufferedReader br = new BufferedReader(reader) // 建立一个对象,它把文件内容转成计算机能读懂的语言  

            String line = ""  

            line = br.readLine()  

            while (line != null) {  

                line = br.readLine() // 一次读入一行数据  

            }  

  

            /* 写入Txt文件 */  

            File writename = new File(".\\result\\en\\output.txt") // 相对路径,如果没有则要建立一个新的output。txt文件  

            writename.createNewFile() // 创建新文件  

            BufferedWriter out = new BufferedWriter(new FileWriter(writename))  

            out.write("我会写入文件啦\r\n") // \r\n即为换行  

            out.flush() // 把缓存区内容压入文件  

            out.close() // 最后记得关闭文件  

  

        } catch (Exception e) {  

            e.printStackTrace()  

        }  

    }  

}

Java程序向数据库中插入数据,代码如下:

//首先创建数据库,(access,oracle,mysql,sqlsever)其中之一,其中access,sqlsever需要配置数据源(odbc)

//然后再eclipse中创建类(ConnDb,Test,TestBean)ConnDb功能为连接数据库,查询,插入,删除,修改数据的类,Test为含有main方法的测试类,TestBean为数据表中的字段属性及set,get方法

//以下是ConnDb代码:

package db

import java.sql.Connection

import java.sql.DriverManager

import 

java.sql.ResultSet

import java.sql.SQLException

import 

java.sql.Statement

import java.util.ArrayList

public class ConnDb {

public Connection startConn(Connection conn){

  try {

   Class.forName("sun.jdbc.odbc.JdbcOdbcDriver")

   conn = DriverManager.getConnection("jdbc:odbc:数据库","用户名", "密码")

  } catch (Exception e) {

   System.out.println("连接数据库时出现错误")

  }

  return conn

 }

 

public ArrayList executeQuery(String sql){

  Connection conn = null

  Statement stmt = null

  ResultSet rs = null

  ArrayList list = new ArrayList()

  try {

   conn = startConn(conn)

   stmt = conn.createStatement()

   rs = stmt.executeQuery(sql)//sql为sql语句例如"select * from 

表名",从main方法中传进来,这里用的是ArrayList 类将查询结果存储起来

   while(rs.next()){

    TestBean tb = new TestBean()

    tb.setTid(rs.getString("tid"))

    tb.setTname(rs.getString("tname"))

    tb.setTinfo(rs.getString("tinfo"))

    list.add(tb)

   }

  } 

catch (SQLException e) {

   // TODO Auto-generated catch block

   e.printStackTrace()

  }finally{

   closeConn(rs,stmt,conn)

  }

  return list

 } 

 public void executeUpdate(String sql){

  Connection conn = null

  Statement stmt = null

  try {

   conn = 

startConn(conn)

   stmt = conn.createStatement()

   stmt.executeUpdate(sql)

  } 

catch (SQLException e) {

   System.out.println("修改,插入或者删除数据库数据时发生错误!")

  }finally{

   closeConn(stmt,conn)

  }

 }

 public void closeConn(ResultSet rs,Statement stmt,Connection conn){

  try {

   if(rs != 

null){

    rs.close()

   }

   if(stmt != null){

    stmt.close()

   }

   if(conn != null){

    conn.close()

   }

  } 

catch (SQLException e) {

   // TODO Auto-generated catch 

block

   System.out.println("关闭数据库的时候发生错误!")

  }

 }

 public void closeConn(Statement stmt,Connection conn){

  try {

   if(stmt != null){

    stmt.close()

   }

   if(conn != null){

    conn.close()

   }

  } 

catch (SQLException e) {

   // TODO Auto-generated catch block

   System.out.println("关闭数据库的时候发生错误!")

  }

 }

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9971396.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-03
下一篇 2023-05-03

发表评论

登录后才能评论

评论列表(0条)

保存