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