File filename=new File(kk);//kk是一个大对象
FileInputStream fis=new FileInputStream(filename);
PreparedStatement ps =con.prepareStatement(sql);
ps.setString(1,"42981");
ps.setString(2,filename.getName());
ps.setString(3,"151");
ps.setBinaryStream(4,fis,(int)filename.length());
ps.executeUpdate();
ps.close();
fis.close();
有些笼统,大概意思吧
FileInputStream fis=new FileInputStream(filename);
PreparedStatement ps =con.prepareStatement(sql);
ps.setString(1,"42981");
ps.setString(2,filename.getName());
ps.setString(3,"151");
ps.setBinaryStream(4,fis,(int)filename.length());
ps.executeUpdate();
ps.close();
fis.close();
有些笼统,大概意思吧
解决方案 »
- poi 生成文件后缀不对
- 新手求助!SSH框架开发的网上书店系统 运行Tomcat不报错 用浏览器进入login.jsp页面时出404错误
- 想在HTML中嵌套EXCEL文件,问问
- 搜索引擎搜索词的传递和转码的问题
- 求个struts用户管理方案
- xmlbeans解析wsdl问题
- 弄了2年JAVA 这次我感觉迷茫了 求助
- ==========如何采用JMS/MDB设计工作流引擎=========(第二贴)
- 我初用webLogic7.0 + jbuilder8.0,数据库是SQLServer2000。请问?????
- 新手怎么上路?
- 程序中读oracle数据库中的clob数据出异常
- 在tomcat+eclipse下运行jsp的问题!
我现在碰到的问题是:可以插入数据但是不全,例如:我要插入"abcd",但是后来的结果是"ab".请问这是怎么回事?怎么解决?谢谢!!
========================
-------------------------------------------------------
有关oracle字段类型的相关信息可以查阅oracle技术网。下面摘抄一些有关blob.clob等类型的说明。又便于大家的了解。
字段类型:blob,clob,nclob
说明:三种大型对象(LOB),用来保存较大的图形文件或带格式的文本文件,如Miceosoft Word文档,以及音频、视频等非文本文件,最大长度是4GB。LOB有几种类型,取决于你使用的字节的类型,Oracle 8i实实在在地将这些数据存储在数据库内部保存。可以执行读取、存储、写入等特殊操作。 我们所操作的clobtest_table中属性是(字符型id,CLOB型picstr),目前我们假设一个大的字符对象str已经包含了我们需要存入picstr字段的数据。而且connection对象conn已经建立。以下的例子程序也因为不想占用太多的空间,所以对抛出异常没有写。大家参考一下api doc。就可以知道该抛出什么异常了,此处仅仅告诉大家如何去写。 代码:
(1)对数据库clob型执行插入操作
*************************************************
java.sql.PreparedStatement pstmt = null;
ResultSet rs = null;
String query = "";
conn.setAutoCommit(false);
query = "insert into clobtest_table(id,picstr) values(?,empty_clob())";
java.sql.PreparedStatement pstmt = conn.prepareStatement(query);
pstmt.setString(1,"001");
pstmt.executeUpdate();
pstmt = null
query = "select picstr from clobtest_table where id = '001' for update";
pstmt = con.prepareStatement(query)
rs= pstmt.executeQuery();
oracle.sql.CLOB clobtt = null;
if(rs.next()){
clobtt = (oracle.sql.CLOB)rs.getClob(1);
}
Writer wr = clobtt.getCharacterOutputStream();
wr.write(strtmp);
wr.flush();
wr.close();
rs.close();
con.commit();
(2)通过sql/plus查询是否已经成功插入数据库
*************************************************
PL/SQL的包DBMS_LOB来处理LOB数据。察看刚才的插入是否成功。使用DBMS_LOB包的getlength这个procedure来检测是否已经将str存入到picstr字段中了。如:
SQL> select dbms_lob.getlength(picstr) from clobtest_table;
(3)对数据库clob型执行读取操作
*************************************************
读取相对插入就很简单了。基本步骤和一半的取数据库数据没有太大的差别。
String description = ""
query = "select picstr from clobtest_table where id = '001'";
pstmt = con.prepareStatement(query);
ResultSet result = pstmt.executeQuery();
if(result.next()){
oracle.jdbc.driver.OracleResultSet ors =
(oracle.jdbc.driver.OracleResultSet)result;
oracle.sql.CLOB clobtmp = (oracle.sql.CLOB) ors.getClob(1);
if(clobtmp==null || clobtmp.length()==0){
System.out.println("======CLOB对象为空 ");
description = "";
}else{
description=clobtmp.getSubString((long)1,(int)clobtmp.length());
System.out.println("======字符串形式 "+description);
}
}