使用PreparedStatement向数据表中插入、修改、删除、获取Blob类型的数据
使用PreparedStatement向数据表中插入、修改、删除、获取Blob类型的数据
Blob介绍
BLOB类型的字段用于存储二进制数据
MySQL中,BLOB是个类型系列,包括:TinyBlob、Blob、MediumBlob、LongBlob,这几个类型之间的唯一区别是在存储文件的最大大小上不同。
MySQL的四种BLOB类型
类型 大小(单位:字节)
TinyBlob 最大 255
Blob 最大 65K
MediumBlob 最大 16M
LongBlob 最大 4G
Oracle LOB介绍
内部LOB将数据以字节流的形式存储在数据库的内部。因而,内部LOB的许多操作都可以参与事务,也可以像处理普通数据一样对其进行备份和恢复操作。Oracle支持三种类型的内部LOB:
- BLOB(二进制数据)
- CLOB(单字节字符数据)
- NCLOB(多字节字符数据)。
CLOB和NCLOB类型适用于存储超长的文本数据,BLOB字段适用于存储大量的二进制数据,如图像、视频、音频,文件等。
目前只支持一种外部LOB类型,即BFILE类型。在数据库内,该类型仅存储数据在操作系统中的位置信息,而数据的实体以外部文件的形式存在于操作系统的文件系统中。因而,该类型所表示的数据是只读的,不参与事务。该类型可帮助用户管理大量的由外部程序访问的文件。
;
. io
.*;
. sql
.*;
. text
. SimpleDateFormat
;
. junit
. Test
;
{
//如何获取数据表中的 blob类型的变量
()
{
=
null
;
=
null
;
=
null
;
=
null
;
=
null
;
try
{
= JDBCUtils
. getConnection
();
= "select id,name,email,birth,photo from customers where id=?"
;
= conn
. prepareStatement
( sql
);
.setInt
(1
, 16
);//获取id=16的数据
= ps
. executeQuery
();
if
( rs
. next
()){
= rs
. getInt
( 1
);
= rs
. getString
( 2
);
= rs
. getString
( 3
);
= rs
. getDate
( 4
);
=rs
.getBlob
(5
);
= photo
. getBinaryStream
();//利用输入流来读取数据库中的二进制文件
=
new FileOutputStream
(
new File
( "girl.png"
));//输出到本地
[] buf
=
new byte
[ 100
];
= 0
;
while
(( len
= is
. read
( buf
))!=- 1
){
. write
( buf
, 0
, len
);
}
=
new Customer
( id
, name
, birth
);//将非blob类型封装成对象输出
. out
. println
( cust
);
}
}
catch
( Exception e
)
{
}
finally
{
. close
( rs
, ps
, conn
);//记得要关闭流
if
( fos
!=
null
){
try
{
. close
();
}
catch
( IOException e
)
{
. printStackTrace
();
}
}
if
( is
!=
null
){
try
{
. close
();
}
catch
( IOException e
)
{
. printStackTrace
();
}
}
}
}
// 修改数据表包含图片信息的数据
()
{
=
null
;
=
null
;
=
null
;
try
{
= JDBCUtils
. getConnection
();
= "update customers set photo = ? where id = ?"
;
= conn
. prepareStatement
( sql
);
=
new FileInputStream
(
new File
( "1.png"
));
.setBlob
(1
, fis
);
. setInt
( 2
, 16
);
.execute
();
}
catch
( Exception e
)
{
. printStackTrace
();
}
finally
{
. close
(
null
,
ps
, conn
);
try
{
. close
();
}
catch
( IOException e
)
{
. printStackTrace
();
}
}
}
// 向数据表中插入一条包含图片信息的数据
()
{
=
null
;
=
null
;
=
null
;
try
{
= JDBCUtils
. getConnection
();
= "insert into customers(name,email,birth,photo)values(?,?,?,?)"
;
= conn
. prepareStatement
( sql
);
. setString
( 1
, " zhengqiang "
);
. setString
( 2
, "beipiao@123.com"
);
= "1991-11-13"
;
=
new SimpleDateFormat
( "yyyy-MM-dd"
);
. util
. Date d
= sdf
. parse
( date
);
. setDate
( 3
,
new Date
( d
. getTime
()));
=
new FileInputStream
(
new File
( "66.jpg"
));
. setBlob
( 4
, fis
);
.execute
();
}
catch
( Exception e
)
{
. printStackTrace
();
}
finally
{
. close
(
null
,
ps
, conn
);
try
{
. close
();
}
catch
( IOException e
)
{
. printStackTrace
();
}
}
}
使用PreparedStatement向数据表中插入、修改、删除、获取Blob类型的数据的更多相关文章
- 向Oracle 数据表中插入一条带有日期类型的数据
有一张表:batch(批次表) 表的字段如下: 第一种情况: 现在需要插入一条当前的系统时间 sql 如下: insert into batch (batch_id, cus_id, batch_nu ...
- 向mysql数据表中插入数据失败的原因
1.案例代码: $sql1="insert into content(category,subject,content,username,release_date) values('{$ca ...
- 触发器修改后保存之前的数据 表中插入数据时ID自动增长
create or replace trigger t before update on test5 for each rowbegin insert into test55 values (:old ...
- sql 所有数据表中 插入字段
declare @tablename varchar(200)declare @sql varchar(2000)declare cur_t cursor forselect name from sy ...
- MySQL 向表中插入、删除数据
一.向表中插入一条信息 1.查看表中的数据 mysql> SELECT * FROM user; +----+---------+----------+ | id | account | pas ...
- Mysql如何向存在外键的数据表中插入数据
1.创建表 CREATE TABLE `trn_comment_msg` ( `comMsgId` ) NOT NULL AUTO_INCREMENT COMMENT '评论消息主键', `msgId ...
- mysql 数据表中查找、删除重复记录
为了性能考虑,在阅读之前提醒大家,如果有子查询,子查询查询到的数据最好不要超过总数据量的30%. 查询有重复数据的记录 select * from F group by a,b,c,d having ...
- Yii1 用commandBuilder方法往数据表中插入多条记录
$builder = Yii::app()->db->schema->commandBuilder; // 创建builder对象 $command = $builder->c ...
- MySQL查询数据表中数据记录(包括多表查询)
MySQL查询数据表中数据记录(包括多表查询) 在MySQL中创建数据库的目的是为了使用其中的数据. 使用select查询语句可以从数据库中把数据查询出来. select语句的语法格式如下: sele ...
随机推荐
- Win7系统安装Centos7.0双系统(一)
项目环境测试,过去在虚拟机安装只要配置好镜像很快就可以轻松安装,但是在真实机中安装就有些略坑.网上有很多说法是把iso文件中安装引导拷出来,试了很久还是觉得U盘镜像直接安装更便捷.靠谱.因为CentO ...
- word embeddding和keras中的embedding
训练好的词向量模型被保存下来,该模型的本质就是一个m*n的矩阵,m代表训练语料中词的个数,n代表训练时我们设定的词向量维度.当我们训练好模型后再次调用时,就可以从该模型中直接获取到对应词的词向量. 通 ...
- 第19课 类型萃取(3)_类型选择的traits
1. std::conditional (1)原型:template <bool Cond, class T, class F> struct conditional; //根据条件获取T ...
- μC/Probe尝鲜
μC/Probe 1.添加文件 2.配置probe_com_cfg.h 2.1.选择接口 #define PROBE_COM_CFG_RS232_EN DEF_ENABLED /* Configure ...
- postgresql数据库3种程序(rule,trigger ,FUNCTION )
1. CREATE [ OR REPLACE ] RULE name AS ON event TO table_name [ WHERE condition ] DO [ ALSO | INSTEAD ...
- linux tail 命令详解
linux ---tail命令 linux中tail命令---用于查看文件内容 最基本的是cat.more和less. 1. 如果你只想看文件的前5行,可以使用head命令,如: head -5 /e ...
- 接口测试工具postman/jmeter基本使用
一.接口的分类: 最常用的两种接口webservice接口和http api接口:1.webservice接口走soap协议通过http传输,请求报文和返回报文都是XML格式,现在测试的时候都通过工具 ...
- SpringBoot 出现Whitelabel Error Page 解决办法
这是咋了,咋的就404了 我路径也挺对的啊 注解也都写上了啊 咋就找不到了呢? debug吧它不进方法 看日志吧,他还不报错 这家伙给我急的 百度一下午也没解决,最后还是看官网才知道错在了那里,程序只 ...
- 编程最好用的字体consolas
python 自带idle最好用的字体consolas https://www.icourse163.org/learn/BIT-268001?tid=1002788003#/learn/forumd ...
- English-英语日常交流语句