java sqlserver text 类型字段读取方法
程序员文章站
2023-12-03 13:06:16
有这样一个需求,需要将原本存储在数据库中的文档转存至文件系统中,于是写了一个简单的程序完成此功能,代码如下: java代码 复制代码 代码如下: import java.i...
有这样一个需求,需要将原本存储在数据库中的文档转存至文件系统中,于是写了一个简单的程序完成此功能,代码如下:
java代码
import java.io.bufferedoutputstream;
import java.io.file;
import java.io.fileoutputstream;
import java.io.ioexception;
import java.sql.connection;
import java.sql.drivermanager;
import java.sql.preparedstatement;
import java.sql.resultset;
import org.dbunit.util.base64;
public class readblob {
/**
* @param args
*/
public static void main(string[] args) throws exception {
class.forname("com.microsoft.sqlserver.jdbc.sqlserverdriver");
connection conn = drivermanager.getconnection(
"jdbc:sqlserver://localhost:1433;databasename=test1", "sa",
"123456");
preparedstatement ps = conn.preparestatement("select * from aa");
resultset rs = ps.executequery();
while(rs.next()){
string filename = rs.getstring("filename");
string content = rs.getstring("content");
byte[] byte_content = base64.decode(content);
generatefile(byte_content, "d:\\doc", filename);
}
conn.close();
}
/**
* 根据byte数组,生成文件
*/
public static void generatefile(byte[] bfile, string filepath,string filename) {
bufferedoutputstream bos = null;
fileoutputstream fos = null;
file file = null;
try {
file dir = new file(filepath);
if(!dir.exists()&&dir.isdirectory()){
dir.mkdirs();
}
file = new file(filepath+"\\"+filename);
fos = new fileoutputstream(file);
bos = new bufferedoutputstream(fos);
bos.write(bfile);
} catch (exception e) {
e.printstacktrace();
} finally {
if (bos != null) {
try {
bos.close();
} catch (ioexception e1) {
e1.printstacktrace();
}
}
if (fos != null) {
try {
fos.close();
} catch (ioexception e1) {
e1.printstacktrace();
}
}
}
}
}
java代码
复制代码 代码如下:
import java.io.bufferedoutputstream;
import java.io.file;
import java.io.fileoutputstream;
import java.io.ioexception;
import java.sql.connection;
import java.sql.drivermanager;
import java.sql.preparedstatement;
import java.sql.resultset;
import org.dbunit.util.base64;
public class readblob {
/**
* @param args
*/
public static void main(string[] args) throws exception {
class.forname("com.microsoft.sqlserver.jdbc.sqlserverdriver");
connection conn = drivermanager.getconnection(
"jdbc:sqlserver://localhost:1433;databasename=test1", "sa",
"123456");
preparedstatement ps = conn.preparestatement("select * from aa");
resultset rs = ps.executequery();
while(rs.next()){
string filename = rs.getstring("filename");
string content = rs.getstring("content");
byte[] byte_content = base64.decode(content);
generatefile(byte_content, "d:\\doc", filename);
}
conn.close();
}
/**
* 根据byte数组,生成文件
*/
public static void generatefile(byte[] bfile, string filepath,string filename) {
bufferedoutputstream bos = null;
fileoutputstream fos = null;
file file = null;
try {
file dir = new file(filepath);
if(!dir.exists()&&dir.isdirectory()){
dir.mkdirs();
}
file = new file(filepath+"\\"+filename);
fos = new fileoutputstream(file);
bos = new bufferedoutputstream(fos);
bos.write(bfile);
} catch (exception e) {
e.printstacktrace();
} finally {
if (bos != null) {
try {
bos.close();
} catch (ioexception e1) {
e1.printstacktrace();
}
}
if (fos != null) {
try {
fos.close();
} catch (ioexception e1) {
e1.printstacktrace();
}
}
}
}
}
推荐阅读
-
java sqlserver text 类型字段读取方法
-
mssql查找备注(text,ntext)类型字段为空的方法
-
java sqlserver text 类型字段读取方法
-
mssql sqlserver text、image字段类型无法使用DISTINCT的处理方法分享
-
mssql查找备注(text,ntext)类型字段为空的方法
-
Java读取Oracle大字段数据(CLOB)的2种方法
-
[sqlserver]在text类型字段中查找字符串出现次数
-
SqlServer2008中便捷查看表字段备注类型默认值的方法
-
问题:Mysql中字段类型为text的值, java使用selectByExample查询为null
-
Java将Date日期类型字段转换成json字符串的方法