1、使用blob将图片保存为二进制格式,(可以用浏览器来转换)随后用base64编码来保存图片,再将base64编码保存进数据库的clob类型字段上。
10年积累的成都网站设计、成都网站制作经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站设计后付款的网站建设流程,更有阳城免费网站建设让你可以放心的选择与我们合作。
2、然后要用一个数据名称System.Data.OracleClient。
3、创建一个储存文件,然后把相关代码写入比如string execSql="insert into clob_table(clob_id,) values(1,:clob_pic);"编写代码的时候注意,后缀的符号(;")也要写入,不然无法进行下一步指令。
4、之前上面用的是base64编码,当显示图片的时候要将图片输出到浏览器流中,不然在base64里面是看不到图片。
5、在输出的时候要把图片转换成二进制(buffur即二进制编码)。
6、随后上传即可,然二进制流也可以存成文件(File)存到FTP服务器,当需要的时候可以根据路径进行下载的。
将图片插入到BLOB类型的字段中
建立一个表:create table a(a blob);
建立一个目录:create directory tmp as 'e:\';
建立一个PL/SQL块:
declare
b_file bfile;
b_lob blob;
begin
insert into a(a) values(empty_blob()) return a into b_lob;
--为了使PL/SQL编译成功,必须先为该列插入一个empty_blob() 值,return a into b_lob将该列与一个blog类型的变量绑定在一起,以后只要为b_lob赋值,即等于将该值插入了表中。
b_file:=bfilename('tmp','filename.jpg');
--tmp是建立的文件所在的目录,filename.jpg是文件名;将文件转换为bfile类型
dbms_lob.open(b_file,dbms_lob.file_readonly);--将b_file 以只读的方式打开
dbms_lob.loadfromfile(b_lob,b_file,dbms_lob.getlength(b_file));-- 将b_file中的内容转换到b_lob中
dbms_lob.close(b_file);
commit;
end;
system下执行
create or replace directory BlobFile as 'C:\TEMP';--路径自己改一下
grant read on directory BlobFile to scott;
scott下建立存放的表
Create Table blobTest(
filename varchar2(200),
filedesc varchar2(200),
filebody blob);
创建过程
Create Or Replace Procedure Proc_loadBlob(p_filename varchar2,p_filedesc varchar2)
Is
src_file bfile;
dst_file BLOB;
lgh_file binary_integer;
Begin
src_file := bfilename('BLOBFILE',p_filename);
insert into blobTest(filename,filedesc,filebody)
values (p_filename,p_filedesc,EMPTY_BLOB())
returning filebody into dst_file;
dbms_lob.fileopen(src_file,dbms_lob.file_readonly);
lgh_file := dbms_lob.getlength(src_file);
dbms_lob.loadfromfile(dst_file,src_file,lgh_file);
update blobTest
set filebody = dst_file
where filename = p_filename;
dbms_lob.fileclose(src_file);
End Proc_loadBlob;
执行插入:
exec Proc_loadBlob('101101.jpeg','给图片命名);
你要是非弄个id的话,可以自己建立一个序列,到时候自增就好了呀
最后给你上图