jdbc基础 (三) 大文本、二进制数据处理
LOB (Large Objects) 分为:CLOB和BLOB,即大文本和大二进制数据
CLOB:用于存储大文本
BLOB:用于存储二进制数据,例如图像、声音、二进制文件
在mysql中,只有BLOB,没有CLOB,mysql存储大文本用TEXT
TEXT 分为:TINYTEXT、TEXT、MEDIUMTEXT和LONGTEXT
BLOB 分为:TINYBLOB、BLOB、MEDIUMBLOB和LONGBLOB
取值范围如下图:

下面来看具体的代码实现:
package com.cream.ice.jdbc; import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.Reader;
import java.io.Writer;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException; import org.junit.Test; /**
* 大文本数据操作
*
* 假设数据库中已存在表test:
* create table test(
* id int primary key,
* content longtext
* );
*
* @author ice
*
*/
public class ClobDemo { Connection connection = null;
PreparedStatement statement = null;
ResultSet resultSet=null; @Test
public void add(){
try {
connection=JdbcUtils.getConnection();
statement=connection.prepareStatement("insert into test (id,content) values (?,?)");
statement.setInt(1, 1); //大文本要使用流的形式。将d:/test.txt内容添加至该记录的content字段
File file = new File("d:/test.txt");
Reader reader = new FileReader(file);
//不能使用long的参数,因为mysql根本支持不到那么大的数据,所以没有实现
statement.setCharacterStream(2, reader, (int)file.length()); int i = statement.executeUpdate();
if(i>0)
System.out.println("插入成功"); } catch (SQLException e) {
e.printStackTrace();
} catch (FileNotFoundException e) {
e.printStackTrace();
} finally{
JdbcUtils.releaseResources(null, statement, connection);
}
} @Test
public void read(){
try {
connection = JdbcUtils.getConnection();
statement = connection.prepareStatement("select * from test where id=?");
statement.setInt(1, 1); //将读取内容保存到E盘上
resultSet = statement.executeQuery();
while(resultSet.next()){
Reader reader = resultSet.getCharacterStream("content");
Writer writer = new FileWriter("e:/test.txt");
char buffer[] = new char[1024];
int len = -1;
while((len=reader.read(buffer))!=-1){
writer.write(buffer, 0, len);
}
reader.close();
writer.close();
}
} catch (Exception e) {
e.printStackTrace();
} finally{
JdbcUtils.releaseResources(resultSet, statement, connection);
}
}
}
package com.cream.ice.jdbc; import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.OutputStream;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet; import org.junit.Test; /**
* 大二进制数据操作
*
* 假设数据库中已存在表test:
* create table test(
* id int primary key,
* content longblob
* );
*
* @author ice
*
*/
public class BlobDemo {
Connection connection = null;
PreparedStatement statement = null;
ResultSet resultSet=null; @Test
public void add(){
try {
connection=JdbcUtils.getConnection();
statement=connection.prepareStatement("insert into test (id,content) values (?,?)");
statement.setInt(1, 1); InputStream in = new FileInputStream("d:/test.jpg");
statement.setBinaryStream(2, in, in.available()); int i = statement.executeUpdate();
if(i>0)
System.out.println("插入成功"); } catch (Exception e) {
e.printStackTrace();
} finally{
JdbcUtils.releaseResources(null, statement, connection);
}
} @Test
public void read(){
try {
connection = JdbcUtils.getConnection();
statement = connection.prepareStatement("select * from test where id=?");
statement.setInt(1, 1); //保存到E盘上
resultSet = statement.executeQuery();
while(resultSet.next()){
InputStream in = resultSet.getBinaryStream("content");
OutputStream out = new FileOutputStream("e:/test.jpg");
byte b[] = new byte[1024];
int len = -1;
while((len=in.read(b))!=-1){
out.write(b, 0, len);
}
out.close();
in.close();
}
} catch (Exception e) {
e.printStackTrace();
} finally{
JdbcUtils.releaseResources(resultSet, statement, connection);
}
}
}
这里使用了我上一篇jdbc基础中的JdbcUtils工具类,同时也使用了单元测试来测试两个成员方法,代码已亲测可运行。
csdn博文地址:jdbc基础 (三) 大文本、二进制数据处理
jdbc基础 (三) 大文本、二进制数据处理的更多相关文章
- 使用JDBC处理MySQL大文本和大数据
LOB,Large Objects,是一种用于存储大对象的数据类型,一般LOB又分为BLOB与CLOB.BLOB通常用于存储二进制数据,比如图片.音频.视频等.CLOB通常用于存储大文本,比如小说. ...
- JDBC中级篇(MYSQL)——处理大文本(CLOB)
注意:其中的JdbcUtil是我自定义的连接工具类:代码例子链接: package b_blob_clob; import java.io.FileNotFoundException; import ...
- JavaWeb学习总结(三十五)——使用JDBC处理Oracle大数据
一.Oracle中大数据处理 在Oracle中,LOB(Large Object,大型对象)类型的字段现在用得越来越多了.因为这种类型的字段,容量大(最多能容纳4GB的数据),且一个表中可以有多个这种 ...
- JavaWeb(三十五)——使用JDBC处理Oracle大数据
一.Oracle中大数据处理 在Oracle中,LOB(Large Object,大型对象)类型的字段现在用得越来越多了.因为这种类型的字段,容量大(最多能容纳4GB的数据),且一个表中可以有多个这种 ...
- 利用JDBC处理mysql大数据--大文本和二进制文件等
转载自http://www.cnblogs.com/xdp-gacl/p/3982581.html 一.基本概念 大数据也称之为LOB(Large Objects),LOB又分为:clob和blob, ...
- javaweb学习总结(三十四)——使用JDBC处理MySQL大数据
一.基本概念 大数据也称之为LOB(Large Objects),LOB又分为:clob和blob,clob用于存储大文本,blob用于存储二进制数据,例如图像.声音.二进制文等. 在实际开发中,有时 ...
- javaweb(三十四)——使用JDBC处理MySQL大数据
一.基本概念 大数据也称之为LOB(Large Objects),LOB又分为:clob和blob,clob用于存储大文本,blob用于存储二进制数据,例如图像.声音.二进制文等. 在实际开发中,有时 ...
- 三.使用JDBC处理MySql大数据
一.基本概念 大数据也称之为LOB(Large Objects),LOB又分为:clob和blob,clob用于存储大文本,blob用于存储二进制数据,例如图像.声音.二进制文等. 在实际开发中,有时 ...
- 使用jdbc存储图片和大文本
package cn.itcast.i_batch; import java.sql.Connection; import java.sql.PreparedStatement; import jav ...
随机推荐
- Core Data数据操作
1.建立学生实体,插入100条数据 2.按条件查询学生数据 3.统计学生信息 4.修改学生信息 5.删除学生数据 import UIKit import CoreData class ViewCont ...
- 在MVC3中使用code first生成数据局库并操作数据库
1.建立Users和UserInfos两个实体类 对应的是数据库中的表 public class User { //类名+Id(User+Id)组成的字符串在数据库表中会设置该字段是主键且是按1的增量 ...
- SQL中case语句的两种方式
- Maximum Subsequence Sum(接上篇)
Given a sequence of K integers { N1, N2, ..., NK }. A continuous subsequence is defined to be { Ni, ...
- 迅为iTOP-4418开发板兼容八核6818开发板介绍
核心板介绍 三星四核S5P4418与八核6818完美兼容 1GB内存/2GB内存可选 电源管理:AXP228,支持动态调频,超低功耗 核心板引出脚最全:四组连接器共320个PIN脚 核心板连接器高度仅 ...
- PHP后门隐藏与维持技巧
在一个成功的测试后,通常会想让特权保持的更久些.留后门的工作就显得至关重要,通常布设的后门包括但不限于数据库权限,WEB权限,系统用户权限等等.此文则对大众后门隐藏的一些思路做科普. AD: 0×00 ...
- leetcode_401_Binary Watch_回溯法_java实现
题目: A binary watch has 4 LEDs on the top which represent the hours (0-11), and the 6 LEDs on the bot ...
- 使用reportNG替换testNG的默认报告
关于reportng的官网介绍:http://reportng.uncommons.org/ 1.下载reportNG的jar包:http://pan.baidu.com/s/1hq5znLU 2.r ...
- Android系列之Fragment(三)----Fragment和Activity之间的通信(含接口回调)
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/ ...
- GetComponent
GetComponent 的几种写法: 1.AutoRotation cmp1=(AutoRotation) GetComponent(typeof(AutoRotation)); 2.AutoRot ...