oracle更新long字段报错,为什么我从Oracle中longrow字段中取到本地的文件,总是乱吗呢?...

我的一段测试代码

下面是文件存入数据库longrow的代码

File f = new File(fileurl);

InputStream is = new FileInputStream(f);

Sting sql = "update tt set  t1 = ?  where t2 = '1'";

PreparedStatement ps = conn.prepareStatement(sql);

ps.setBinaryStream(1,is,(int)f.length() );

ps.executeUpdate();//将文件流插入到数据库中。

下面是我取文件,在本地创建文件的代码

InputStream is = null;

int size = 0;

ResultSet rs = stmt.executeQuery("select t1 from tt where t2 = '1'");

rs.next();

is = rs.getBinaryStream("t1") ;

int flen = is.available();

byte temp[] = new byte [flen];

int fread = is.read(temp);

File fileout = new File(fileurl);

fileout.createNewFile() ;

FileOutputStream fouts = new FileOutputStream(fileout);

fouts.write(temp) ;

文件存进去了一个Word文件,也取出来在本地创建了,但我打开word里面却是乱吗??

|

请问你的数据库charset是什么,有可能需要通过String的getBytes转换

|

用如下方法读取:

InputStream is = null;

int size = 0;

ResultSet rs = stmt.executeQuery("select t1 from tt where t2   = '1'");

rs.next();

is = rs.getBinaryStream("t1") ;

int flen = is.available();

byte temp[] = new byte [flen];

int fread = is.read(temp);

/**

还可以试用这种方法:

InputStreamReader ir=new InputStreamReader(is,"GB2312");

byte temp[] = new byte [flen];

int fread = is.read(temp);

*/

File fileout = new File(fileurl);

fileout.createNewFile() ;

OutputStreamWriter ow=new OutputStreamWriter(new  FileOutputStream(fileout),"GB2312");

ow.write(temp) ;

//

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值