JDBC -6- 获取主键 -- LOB

取得数据库自动生成的主键

····································

public class getDataBaseKEY {
    /*
    取得数据库自动生成的主键
     */
    @Test
    public void test() throws Exception{
        String sql = "INSERT INTO customer (name, email, brith) VALUES (?,?,?)";
        PreparedStatement preparedStatement = JDBCTools.getConnection().prepareStatement(sql, Statement.RETURN_GENERATED_KEYS);
        preparedStatement.setObject(1,"awsl");
        preparedStatement.setObject(2,"awsl.com");
        preparedStatement.setObject(3,"awsldata-1235");
        preparedStatement.executeUpdate();
        ResultSet generatedKeys = preparedStatement.getGeneratedKeys();
        if (generatedKeys.next()){
            System.out.println(generatedKeys.getObject(1));
        }
    }
}

Oracle LOB

·················

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

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

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

CLOB和NCLOB类型适用于存储超长的文本数据,BLOB字段适用于存储大量的二进制数据,如图像、视频、音频,文件等。
目前只支持一种外部LOB类型,即BFILE类型。在数据库内,该类型仅存储数据在操作系统中的位置信息,而数据的实体以外部文件的形式存在于操作系统的文件系统中。因而,该类型所表示的数据是只读的,不参与事务。该类型可帮助用户管理大量的由外部程序访问的文件。

Mysql BLOB

··················

MySQL中,BLOB是一个二进制大型对象,是一个可以存储大量数据的容器,它能容纳不同大小的数据。
MySQL的四种BLOB类型(除了在存储的最大信息量上不同外,他们是等同的)
实际使用中根据需要存入的数据大小定义不同的BLOB类型。需要注意的是:如果存储的文件过大,数据库的性能会下降。

在这里插入图片描述

使用JDBC来写入Blob型数据到Oracle中

Oracle的Blob字段比long字段的性能要好,可以用来保存如图片之类的二进制数据。

Oracle的BLOB字段由两部分组成:数据(值)和指向数据的指针(定位器)。尽管值与表自身一起存储,但是一个BLOB列并不包含值,仅有它的定位指针。为了使用大对象,程序必须声明定位器类型的本地变量。
当Oracle内部LOB被创建时,定位器被存放在列中,值被存放在LOB段中,LOB段是在数据库内部表的一部分。
因为Blob自身有一个cursor,当写入Blob字段必须使用指针(定位器)对Blob进行操作,因而在写入Blob之前,必须获得指针(定位器)才能进行写入
如何获得Blob的指针(定位器) :需要先插入一个empty的blob,这将创建一个blob的指针,然后再把这个empty的blob的指针查询出来,这样通过两步操作,就获得了blob的指针,可以真正的写入blob数据了。

步骤

1、插入空blob insert into javatest(name,content) values(?,empty_blob());

2、获得blob的cursor select content from javatest where name= ? for update; 注意: 须加for update,锁定该行,直至该行被修改完毕,保证不产生并发冲突。

3、利用 io,和获取到的cursor往数据库写数据流

Mysql插入大文件

//BLOB(large object): 必须使用PreparedStatement 因为文件时无法拼写的
public class BLOB {
    @Test
    public void test() throws FileNotFoundException {
        String sql = "INSERT INTO blob (data) VALUES(?)";
        File file = new File("C:\\Users\\yuanqi\\IdeaProjects\\JDBC\\src\\connect\\timg (6.jpg");
        FileInputStream fileInputStream = new FileInputStream(file);
        P_Update(sql,fileInputStream);
    }
    public static void P_Update(String sql, Object ... args){
        try {
            PreparedStatement preparedStatement = JDBCTools.getConnection().prepareStatement(sql, Statement.RETURN_GENERATED_KEYS);
            preparedStatement.setBinaryStream(1, (InputStream) args[0]);
            //preparedStatement.setBlob(1, (InputStream) args[0]);
            preparedStatement.executeUpdate();
            ResultSet generatedKeys = preparedStatement.getGeneratedKeys();
            if (generatedKeys.next()){
                System.out.println(generatedKeys.getInt(1));
            }
            preparedStatement.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值