简单记录Oracle中blob存储文件

本文介绍:使用Mybaits Oracle BLOB存储,以PDF文件为例

一、将PDF文件存储到BLOB的接口

二、读取BLOB并返回PDF格式的接口

话不多说,直接上代码

  1. 创建表
CREATE TABLE "TEST_PDF" (
  "ID" VARCHAR2(50 BYTE) VISIBLE NOT NULL,
  "PDF" BLOB VISIBLE
)
-- ----------------------------
-- Primary Key structure for table TEST_PDF
-- ----------------------------
ALTER TABLE "TEST_PDF" ADD CONSTRAINT "SYS_C0014432" PRIMARY KEY ("ID");
  1. mybatis配置
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.mapper.TestPdfMapper">

    <resultMap id="BaseResultMap" type="com.bean.TestPdf">
        <!--@mbg.generated-->
        <!--@Table TEST_PDF-->
        <id column="ID" jdbcType="VARCHAR" property="id" />
        <result column="PDF" jdbcType="BLOB" property="pdf" />
    </resultMap>

    <select id="getone" resultMap="BaseResultMap">
        select ID, PDF
        from test_pdf where rownum =1
    </select>

    <insert id="insertOne" parameterType="com.bean.TestPdf">
        <!--@mbg.generated-->
        insert into TEST_PDF (ID
        <if test="savePdf.binaryStream != null">
            , PDF
        </if>
        )
        values (#{id,jdbcType=VARCHAR}
        <if test="savePdf.binaryStream != null">
            , #{savePdf.binaryStream,jdbcType=BLOB}
        </if>
        )
    </insert>
</mapper>

  1. mapper层
package com.mapper;

import com.bean.TestPdf;
import org.apache.ibatis.annotations.Mapper;

@Mapper
public interface TestPdfMapper {
    TestPdf getone();
    int insertOne(TestPdf testPdf);
}
  1. Java bean
package com.bean;
import lombok.Data;

import java.sql.Blob;

@Data
public class TestPdf {
    private  String id;
    private  byte[] pdf;
    private Blob savePdf;
}

  1. controller层
package com.action;

import com.bean.TestPdf;
import com.mapper.TestPdfMapper;
import com.sys.utils.UUIDUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpHeaders;
import org.springframework.http.HttpStatus;
import org.springframework.http.MediaType;
import org.springframework.http.ResponseEntity;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.multipart.MultipartFile;

import javax.servlet.http.HttpServletResponse;
import javax.sql.rowset.serial.SerialBlob;
import java.io.IOException;
import java.sql.SQLException;

@Controller
@RequestMapping("/testblob")
public class TestPdfAction {
    @Autowired
    TestPdfMapper testPdfMapper;

	/*PDF文件上传存储到oracle blob接口*/
    @RequestMapping("/insertpdf")
    public void insertpdf(@RequestParam("file") MultipartFile multipartFile) throws IOException, SQLException {
        TestPdf testPdf = new TestPdf();
        testPdf.setId(UUIDUtils.getUUID());
        testPdf.setSavePdf(new SerialBlob(multipartFile.getBytes()));
        testPdfMapper.insertOne(testPdf);
    }

	/*PDF文件blob读取*/
    @RequestMapping("/showpdf")
    public ResponseEntity showpdf(HttpServletResponse response){
        TestPdf getone = testPdfMapper.getone();
        HttpHeaders headers = new HttpHeaders();
        headers.setContentType(MediaType.APPLICATION_PDF);
        return  new ResponseEntity(getone.getPdf(), headers, HttpStatus.OK);
    }
}

end 完结!!!

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: OracleBLOB和CLOB都是用来存储大型二进制和字符数据的数据类型,但是它们之间有一些区别。 BLOB是二进制大型对象,用于存储二进制数据,例如图像、音频和视频等。BLOB数据可以通过二进制流进行读取和写入。 CLOB是字符大型对象,用于存储字符数据,例如文本和XML等。CLOB数据可以通过字符流进行读取和写入。 另外,BLOB和CLOB在存储和检索时的处理方式也有所不同。BLOB数据可以使用OracleBLOB API进行处理,而CLOB数据可以使用Oracle的CLOB API进行处理。 ### 回答2: 在Oracle数据库BLOB和CLOB都是用于存储大型二进制对象(LOB)的数据类型。但是,它们之间存在一些区别。 首先,BLOB(Binary Large Object)用于存储二进制数据,例如图像、音频和视频文件等。而CLOB(Character Large Object)用于存储字符数据,例如文本文档和HTML页面等。 其次,BLOB存储时不会进行字符集转换,而CLOB则需要转换为数据库的字符集。这意味着当您插入或更新BLOB数据时,它将保持原样,而CLOB数据可能会因为字符集转换而发生变化。因此,在处理文本数据时应该使用CLOB,而在处理二进制数据时应该使用BLOB。 另外,BLOB可以存储二进制文件,并且是二进制安全的,这意味着它可以存储任意二进制数据。而CLOB只能存储字符数据,因此无法存储二进制文件。 最后,由于BLOB和CLOB存储的数据量可能非常大,因此它们的操作方式也有所不同。通常情况下,您不应该使用SELECT *查询BLOB和CLOB列,因为它们会返回非常大的数据块并导致性能问题。相反,您应该使用子选择语句或分段读取(chunking)等技术来处理LOB数据。 总之,在Oracle数据库BLOB和CLOB是用于存储大型对象的非常有用的数据类型,但是要注意它们之间的差异并适当地使用它们以获得最佳性能和效果。 ### 回答3: Oracle数据库是一种关系型数据库管理系统。它支持许多数据类型以适应不同的场景,其包括BLOB和CLOB类型。BLOB和CLOB类型是两种不同的数据类型,它们在使用和存储方面有着一些不同之处。 BLOB是二进制大型对象(Binary Large Object)的缩写,存储的是二进制数据,例如图片、音乐、视频等等。它可以存储最大长度达到4GB的二进制数据。BLOB数据可以直接存储数据库,也可以被存储文件系统。当需要操作BLOB数据时,可以使用内置的函数来读取、写入或更新数据。 CLOB是字符大型对象(Character Large Object)的缩写,存储的是文本数据,例如文章、邮件、代码等等。它可以存储最大长度达到4GB的文本数据。CLOB数据也可以直接存储数据库,但由于其大小通常比BLOB更大,因此它们也可以被存储文件,而不是存储在表。当需要处理CLOB数据时,也可以使用内置的函数进行读取、写入或更新。 BLOB和CLOB在使用方式上也有所不同。BLOB数据更适合用于媒体数据的存储和处理,例如图片、音乐、视频等。而CLOB数据则更适合用于文本数据的存储和处理,例如文章、邮件、代码等。通常来说,CLOB比BLOB更易于处理和查询,因为它们是基于文本的数据类型,可以使用文本搜索和其他文本处理功能。 总之,在Oracle数据库BLOB和CLOB是两种不同的数据类型,用途和存储方式也不同。BLOB用于存储二进制数据,例如图片、音乐、视频等;而CLOB用于存储文本数据,例如文章、邮件、代码等。了解它们之间的差异可以帮助你选择正确的数据类型,并更好地进行数据库管理和维护。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值