使用PreparedStatement向数据表中插入、修改、删除、获取Blob类型的数据

2014-09-07 20:17

Blob介绍

BLOB类型的字段用于存储二进制数据

MySQL中,BLOB是个类型系列,包括:TinyBlob、Blob、MediumBlob、LongBlob,这几个类型之间的唯一区别是在存储文件的最大大小上不同。

MySQL的四种BLOB类型
类型       大小(单位:字节)
TinyBlob 最大 255
Blob 最大 65K
MediumBlob 最大 16M
LongBlob 最大 4G

Oracle LOB介绍

    LOB,即Large Objects(大对象),是用来存储大量的二进制和文本数据的一种数据类型(一个LOB字段可存储可多达4GB的数据)。

LOB 分为两种类型:内部LOB和外部LOB。

内部LOB将数据以字节流的形式存储在数据库的内部。因而,内部LOB的许多操作都可以参与事务,也可以像处理普通数据一样对其进行备份和恢复操作。Oracle支持三种类型的内部LOB:
  1. BLOB(二进制数据)
  2. CLOB(单字节字符数据)
  3. NCLOB(多字节字符数据)。

CLOB和NCLOB类型适用于存储超长的文本数据,BLOB字段适用于存储大量的二进制数据,如图像、视频、音频,文件等。

目前只支持一种外部LOB类型,即BFILE类型。在数据库内,该类型仅存储数据在操作系统中的位置信息,而数据的实体以外部文件的形式存在于操作系统的文件系统中。因而,该类型所表示的数据是只读的,不参与事务。该类型可帮助用户管理大量的由外部程序访问的文件。



程序示例:

package  tan
;
import  java
.  io
.*;
import  java
.  sql
.*;
import  java
.  text
. SimpleDateFormat
;
import  org
.  junit
. Test
;
public  class  TestJDBC 
{
    

//如何获取数据表中的 blob类型的变量

    @Test
     public  void  testBlob2
() 
{
        Connection conn 
=
null
;
        PreparedStatement ps 
=
null
;
        ResultSet rs 
=
null
;
        InputStream is 
=
null
;
        FileOutputStream fos 
=
null
;
         
try 
{
            conn 
= JDBCUtils 
. getConnection 
();
            String sql 
= "select id,name,email,birth,photo from customers where id=?"
;
            ps 
= conn 
. prepareStatement 
( sql 
);
            ps  
.setInt 
(1
, 16
);//获取id=16的数据
            rs 
= ps 
. executeQuery 
();
             
if
( rs
. next
()){
                  int  id 
= rs 
. getInt 
( 1
);
                String name 
= rs 
. getString 
( 2
);
                String email 
= rs 
. getString 
( 3
);
                Date birth 
= rs 
. getDate 
( 4
);
                Blob photo  
=rs 
.getBlob 
(5
);
                is 
= photo 
. getBinaryStream 
();//利用输入流来读取数据库中的二进制文件
                fos 
=
new  FileOutputStream 
(
new  File
( "girl.png"
));//输出到本地
                
                  byte 
[] buf 
=
new  byte
[  100
];
                  int  len 
= 0
;
                 
while
(( len
= is
. read
( buf
))!=-
){
                    fos 
. write 
( buf 
, 0
,  len
);
                 
}
                Customer cust 
=
new  Customer 
( id 
,  name 
,  email
,  birth
);//将非blob类型封装成对象输出
                System 
. out 
. println 
( cust 
);
             
}
            
            
         
} 
catch 
( Exception e 
) 
{
            
         
}
finally
{
            JDBCUtils 
. close 
( rs 
,  ps 
,  conn 
);//记得要关闭流
             
if
( fos 
!= 
null
){
                 
try 
{
                    fos 
. close 
();
                 
} 
catch 
( IOException e 
) 
{
                    e 
. printStackTrace 
();
                 
}
                
             
}
             
if
( is 
!= 
null
){
                 
try 
{
                    is 
. close 
();
                 
} 
catch 
( IOException e 
) 
{
                      // TODO Auto-generated catch block
                    e 
. printStackTrace 
();
                 
}
                
             
}
         
}
    
}
    

// 修改数据表包含图片信息的数据

    @Test
     public  void  testBlob1
() 
{
        Connection conn 
=
null
;
        PreparedStatement ps 
=
null
;
        FileInputStream fis 
=
null
;
         
try 
{
            conn 
=  JDBCUtils 
. getConnection 
();
            String sql 
=  "update customers set photo = ? where id = ?"
;
            ps 
=  conn 
. prepareStatement 
( sql 
);
              //  填充占位符
            fis 
= 
new  FileInputStream 
(
new  File
( "1.png" 
));
            ps  
.setBlob 
(1
, fis
);
            ps 
. setInt 
( 2
,  16 
);
            ps  
.execute 
();
            
         
} 
catch 
( Exception e 
) 
{
            e 
. printStackTrace 
();
         
}
finally
{
            JDBCUtils 
. close 
(
null
, 
ps
,  conn
);
             
try 
{
                fis 
. close 
();
             
} 
catch 
( IOException e 
) 
{
                e 
. printStackTrace 
();
             
}
         
}
        
    
}

// 向数据表中插入一条包含图片信息的数据

    @Test
     public  void  testBlob
() 
{
        Connection conn 
=
null
;
        PreparedStatement ps 
=
null
;
        FileInputStream fis 
=
null
;
         
try 
{
            conn 
= JDBCUtils 
. getConnection 
();
            String sql 
= "insert into customers(name,email,birth,photo)values(?,?,?,?)"
;
            ps 
= conn 
. prepareStatement 
( sql 
);
            ps 
. setString 
( 1
,  "  zhengqiang "
);
            ps 
. setString 
( 2
,  "beipiao@123.com" 
);
              // 日期转换
            String date 
= "1991-11-13"
;
            SimpleDateFormat sdf 
=
new  SimpleDateFormat
( "yyyy-MM-dd"
);
            java 
. util 
. Date d 
= sdf 
. parse 
( date 
);

            ps 
. setDate 
( 3
, 
new  Date
( d
. getTime
()));

            //利用文件输入流写入
            fis 
=
new  FileInputStream 
(
new  File
( "66.jpg" 
));
            ps 
. setBlob 
( 4
,  fis
);
              // 执行预编译语句
            ps  
.execute 
();
            
         
} 
catch 
( Exception e 
) 
{
            e 
. printStackTrace 
();
         
}
finally
{
            JDBCUtils 
. close 
(
null
, 
ps
,  conn
);
            
try 
{
                fis 
. close 
();
             
} 
catch 
( IOException e 
) 
{
                e 
. printStackTrace 
();
             
}

         
}
        
    
}
    
}

使用PreparedStatement向数据表中插入、修改、删除、获取Blob类型的数据的更多相关文章

  1. 向Oracle 数据表中插入一条带有日期类型的数据

    有一张表:batch(批次表) 表的字段如下: 第一种情况: 现在需要插入一条当前的系统时间 sql 如下: insert into batch (batch_id, cus_id, batch_nu ...

  2. 向mysql数据表中插入数据失败的原因

    1.案例代码: $sql1="insert into content(category,subject,content,username,release_date) values('{$ca ...

  3. 触发器修改后保存之前的数据 表中插入数据时ID自动增长

    create or replace trigger t before update on test5 for each rowbegin insert into test55 values (:old ...

  4. sql 所有数据表中 插入字段

    declare @tablename varchar(200)declare @sql varchar(2000)declare cur_t cursor forselect name from sy ...

  5. MySQL 向表中插入、删除数据

    一.向表中插入一条信息 1.查看表中的数据 mysql> SELECT * FROM user; +----+---------+----------+ | id | account | pas ...

  6. Mysql如何向存在外键的数据表中插入数据

    1.创建表 CREATE TABLE `trn_comment_msg` ( `comMsgId` ) NOT NULL AUTO_INCREMENT COMMENT '评论消息主键', `msgId ...

  7. mysql 数据表中查找、删除重复记录

    为了性能考虑,在阅读之前提醒大家,如果有子查询,子查询查询到的数据最好不要超过总数据量的30%. 查询有重复数据的记录 select * from F group by a,b,c,d having ...

  8. Yii1 用commandBuilder方法往数据表中插入多条记录

    $builder = Yii::app()->db->schema->commandBuilder; // 创建builder对象 $command = $builder->c ...

  9. MySQL查询数据表中数据记录(包括多表查询)

    MySQL查询数据表中数据记录(包括多表查询) 在MySQL中创建数据库的目的是为了使用其中的数据. 使用select查询语句可以从数据库中把数据查询出来. select语句的语法格式如下: sele ...

随机推荐

  1. 【比赛打分展示双屏管理系统-专业版】Other.ini 配置文件解读以及排行榜界面及专家评语提交展示等具体配置

    第一个问题:Other.ini配置文件的解读: 在软件根目录下,找到Other.ini配置文件,打开如下: 配置文件解读: iOrderIDOrXSID:默认为0,按照软件 选项/排行榜和奖项 的设置 ...

  2. javascript中let和var的区别

    let是es6中新增命令,也是用来声明变量的,可能很多小伙伴都像我一样,定义变量的时候都会用var而很少用到let,那么,let和var到底有什么区别呢? let和var的区别体现在作用域上.var的 ...

  3. SpringMvc 使用Thumbnails压缩图片

    ```java @PostMapping(value = "/upLoadFile") @ApiOperation(value = "上传文件") public ...

  4. 一个linux 4.9,4.14内核的bbr带宽估计偏低问题

    linux 4.9内核,bbr的带宽估计问题. 一个正常的bbr流量图: 对应的ttl图形: 一个异常的bbr流量图: 可以看出,异常的bbr流量图,出现了一个很低的带宽,且稳定在这个带宽10s左右, ...

  5. java.lang.String (JDK1.8)

    String类实现了java.io.Serializable, Comparable<String>, CharSequence这三个interface. 看了下这三个interface中 ...

  6. user story

    What is a user story? A user story is a short description of something that your customer will do wh ...

  7. href,src,url三者区别。

    在html中: href(Hypertext Reference)指向网络上的资源,在现有元素(如a标签)或现有文档(如link)与目标锚或资源之间建立链接. 建立链接的过程中,浏览器不会停止解析所在 ...

  8. c# devexpress 多文档界面

    学习记录 https://blog.csdn.net/qq_25473787/article/details/81208894?utm_source=blogxgwz0

  9. Flask最强攻略 - 跟DragonFire学Flask - 第一篇 你好,我叫Flask

    首先,要看你学没学过Django 如果学过Django 的同学,请从头看到尾,如果没有学过Django的同学,并且不想学习Django的同学,轻饶过第一部分 一. Python 现阶段三大主流Web框 ...

  10. 【python原理解析】gc原理初步解析

    python的gc是会用到:引用计数.标记-清除和分代收集,首先说明一下什么是引用计数 可以通过sys模块中的getrefcount()方法获取某个对象的引用计数 python本身的数据类型有基础类型 ...