3.2JDBC学习——使用CLOB和BLOB处理大文本数据

JAVAWEB文章索引
CLOB例子:
在实际开发中,CLOB用于存储大文本数据,但是对于mysql而言,大文本数据的存储是用text类型表示的。
首先我们先建一张表:
bigtexttest(id,text),其中text设置为longtext类型。再在src下面放了一个文件,软件安装.txt。
下面我们进行大文本数据的写入。
代码:

    public static void ClOBTest() {
        Connection conn = DBUtils.getConnection();
        String sql = "insert into bigtexttest(id,text) values(?,?)";
        try {
            PreparedStatement psttm = conn.prepareStatement(sql);   
            File file = new File(".\\src\\软件安装.txt");
            Reader reader = new InputStreamReader(new FileInputStream(file));
            psttm.setInt(1, 1);
            psttm.setCharacterStream(2, reader,(int)file.length());
            psttm.executeUpdate();
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

BLOB例子
BLOB类型的操作与CLOB类似,只是BLOB专门用于存放二进制数据,如图片、电影等。
这里的先建一张表img_test(id,img),其中img是blob类型,然后在src下面放一张图片1.jpg
插入代码如下:

    public static void BLOBInsertTest() {
        PreparedStatement psttm = null;
        Connection conn = DBUtils.getConnection();
        String sql="insert into img_test(id,img) values(?,?)";
        try {
            psttm = conn.prepareStatement(sql);

            File file = new File(".//src//1.jpg");
            InputStream in = new FileInputStream(file);

            psttm.setInt(1, 1);
            psttm.setBinaryStream(2, in,(int)file.length());
            psttm.executeUpdate();
        } catch (SQLException e) {
            e.printStackTrace();
        }catch (FileNotFoundException e) {
            e.printStackTrace();
        }finally {
            DBUtils.close(conn, psttm);
        }
    }

读取代码如下

    public static void BLOBSelectTest() {
        Connection conn = DBUtils.getConnection();
        String sql = "select * from img_test where id = 1";
        try {
        ResultSet rs = conn.prepareStatement(sql).executeQuery();
        if(rs.next()) {
            InputStream in = rs.getBinaryStream("img");
            FileOutputStream out = new FileOutputStream(".\\src\\2.jpg");
            int temp;
            while((temp = in.read()) != -1) {
                out.write(temp);
            }
            out.close();
            in.close();
        }
        }catch (Exception e) {
            e.printStackTrace();
        }finally {
            DBUtils.close(conn);
        }
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值