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);
        }
    }

猜你喜欢

转载自blog.csdn.net/smallhc/article/details/80763409