Antara muka
ResultSet menyediakan kaedah bernama getClob() dan getCharacterStream() untuk mendapatkan semula jenis data Clob, yang biasanya menyimpan kandungan fail.
Kaedah ini menerima integer yang mewakili indeks lajur (atau nilai rentetan yang mewakili nama lajur) dan mendapatkan semula nilai pada lajur yang ditentukan
Perbezaannya ialah kaedah getClob() mengembalikan objek Clob, manakala getCgaracterStream(. ) kaedah mengembalikan Clob yang mengandungi objek Pembaca kandungan jenis data.
Andaikan kita mencipta jadual yang dipanggil Artikel dalam pangkalan data dengan penerangan berikut.
+---------+--------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +---------+--------------+------+-----+---------+-------+ | Name | varchar(255) | YES | | NULL | | | Article | longtext | YES | | NULL | | +---------+--------------+------+-----+---------+-------+
Dan, kami telah memasukkan tiga artikel di dalamnya bernama Artikel 1, Artikel 2 dan Artikel 3 seperti yang ditunjukkan di bawah:
Program berikut mengambil jadual menggunakan kaedah getString() dan getClob() Artikel kandungan dan simpan dalam fail yang ditentukan.
import java.io.FileWriter; import java.io.Reader; import java.sql.Clob; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; public class RetrievingFileFromDatabase { public static void main(String args[]) throws Exception { //Registering the Driver DriverManager.registerDriver(new com.mysql.jdbc.Driver()); //Getting the connection String mysqlUrl = "jdbc:mysql://localhost/sampleDB"; Connection con = DriverManager.getConnection(mysqlUrl, "root", "password"); System.out.println("Connection established......"); //Creating aStatement Statement stmt = con.createStatement(); //Retrieving the data ResultSet rs = stmt.executeQuery("select * from Articles"); int j = 0; System.out.println("Contents of the table are: "); while(rs.next()) { System.out.println(rs.getString("Name")); Clob clob = rs.getClob("Article"); Reader reader = clob.getCharacterStream(); String filePath = "E:\Data\clob_output"+j+".txt"; FileWriter writer = new FileWriter(filePath); int i; while ((i = reader.read())!=-1) { writer.write(i); } writer.close(); System.out.println(filePath); j++; } } }
Connection established...... Contents of the table are: article1 E:\Data\clob_output0.txt article2 E:\Data\clob_output1.txt article3 E:\Data\clob_output2.txt
Atas ialah kandungan terperinci Bagaimanakah kita boleh mendapatkan semula fail daripada pangkalan data menggunakan JDBC?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!