LOB,Large Objects,是一种用于存储大对象的数据类型,一般LOB又分为BLOB与CLOB。BLOB通常用于存储二进制数据,比如图片、音频、视频等。CLOB通常用于存储大文本,比如小说。

MySQL数据库中没有专门的CLOB数据类型,而如果要存储大文本,MySQL采用的是TEXT类型。TEXT类型又有TINYTEXT、TEXT、MEDIUMTEXT和LONGTEXT之分。MySQL中的BLOB类型又可分为TINYBLOB、BLOB、MEDIUMBLOB和LONGBLOB。

使用JDBC处理大文本

向MySQL中存储大文本,可调用JDBC API中PreparedStatement的如下方法:

// 将指定参数设置为给定 Reader 对象

void setCharacterStream(int parameterIndex, Reader reader) throws SQLException

// 将给定参数设置为给定 Reader 对象,该对象具有给定字符数长度(int型)

void setCharacterStream(int parameterIndex, Reader reader, int length) throws SQLException

// 将指定参数设置为给定 Reader 对象,该对象具有给定字符数长度(long型)

void setCharacterStream(int parameterIndex, Reader reader, long length) throws SQLException

如果需要从MySQL数据库中获取大文本列字段值,则可以使用ResultSet的如下方法:

// 以 java.io.Reader 对象的形式获取此 ResultSet 对象的当前行中指定列的值

Reader getCharacterStream(int columnIndex) throws SQLException Reader getCharacterStream(String columnLabel) throws SQLException

// 以 String 的形式获取此 ResultSet 对象的当前行中指定列的值

String getString(int columnIndex) throws SQLException String getString(String columnLabel) throws SQLException

示例:

代码:

import java.io.File;

import java.io.FileNotFoundException;

import java.io.FileReader;

import java.io.IOException;

import java.io.Reader;

import java.sql.Connection;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

import java.sql.SQLException;

/**  * 使用JDBC操作大文本

*  * @author

*  */

public class ClobTest {

/**      * 使用JDBC向数据库表中插入大文本数据

*      * @throws SQLException

*/

public static void add() throws SQLException {

Connection conn = null;

PreparedStatement pstmt = null;

// 获取数据库会话对象

JdbcSession session = JdbcSessionFactory.getCurrentSession();

// 获取数据库连接

conn = session.getConnection();

// 创建SQL语句:向小说表中添加一条章节内容的记录

String sql = "INSERT INTO novel(content) VALUES(?)";

// 创建PreparedStatement对象

pstmt = conn.prepareStatement(sql);

// 创建Reader对象

File file = new File(Thread.currentThread().getClass().getResource("/novel/1.txt").getPath());

Reader reader = null;

try {

reader = new FileReader(file);

} catch (FileNotFoundException e) {

e.printStackTrace();

}

// 设置参数

pstmt.setCharacterStream(1, reader, (int) file.length());

// 执行SQL语句

int count = pstmt.executeUpdate();

// 处理结果

if (count > 0)

System.out.println("添加成功");

else

System.out.println("添加失败");

// 释放资源

JdbcResourceManager.close(pstmt);

JdbcResourceManager.close(conn);

JdbcSessionFactory.closeSession();

}

public static void read() throws SQLException {

Connection conn = null;

PreparedStatement pstmt = null;

ResultSet rs = null;

// 获取数据库会话对象

JdbcSession session = JdbcSessionFactory.getCurrentSession();

// 获取数据库连接

conn = session.getConnection();

// 创建SQL语句

String sql = "SELECT id, content FROM novel";

// 创建PreparedStatement对象

pstmt = conn.prepareStatement(sql);

// 执行SQL语句

rs = pstmt.executeQuery();

// 处理结果

while (rs.next()) {

// 读取小说内容

Reader reader = rs.getCharacterStream("content");

int ch;

try {

while((ch = reader.read()) != -1){

System.out.print((char)ch);

}

} catch (IOException e) {

e.printStackTrace();

}

}

// 释放资源

JdbcResourceManager.close(rs);

JdbcResourceManager.close(pstmt);

JdbcResourceManager.close(conn);

JdbcSessionFactory.closeSession();

}

public static void main(String[] args) {

try {

add();

read();

} catch (SQLException e) {

e.printStackTrace();

}

}

}

使用JDBC处理二进制数据     

向MySQL中存储二进制数据,可调用JDBC API中PreparedStatement的如下方法:

// 将指定参数设置为给定输入流。

void setBinaryStream(int parameterIndex, InputStream x)

// 将指定参数设置为给定输入流,该输入流将具有给定字节数(int型)。

void setBinaryStream(int parameterIndex, InputStream x, int length)

// 将指定参数设置为给定输入流,该输入流将具有指定字节数(long型)。

void setBinaryStream(int parameterIndex, InputStream x, long length)

如果需要从MySQL数据库中获取二进制列字段值,则可以使用ResultSet的如下方法:

// 以未解释字节的流的形式获取此 ResultSet 对象的当前行中指定列的值。

InputStream getBinaryStream(int columnIndex)

// 以未解释的 byte 流的形式获取此 ResultSet 对象的当前行中指定列的值。

InputStream getBinaryStream(String columnLabel)

// 以 Java 编程语言中 Blob 对象的形式获取此 ResultSet 对象的当前行中指定列的值。

Blob getBlob(int columnIndex)

// 以 Java 编程语言中 Blob 对象的形式获取此 ResultSet 对象的当前行中指定列的值。

Blob getBlob(String columnLabel)

获取Blob对象后可以继续调用getBinaryStream()方法获取输入流。

示例:

代码:

import java.io.File;

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;

/**  * 使用JDBC操作二进制数据

*  * @author

*  */

public class BlobTest {

/**      * 插入二进制数据到数据库

*      * @throws Exception

*/

public static void add() throws Exception {

Connection conn = null;

PreparedStatement pstmt = null;

// 获取数据库会话对象

JdbcSession session = JdbcSessionFactory.getCurrentSession();

// 获取数据库连接

conn = session.getConnection();

// 插入音乐数据的SQL语句

String sql = "INSERT INTO music(content) VALUES(?)";

pstmt = conn.prepareStatement(sql);

// 创建PreparedStatement对象

pstmt = conn.prepareStatement(sql);

// 创建Reader对象

File file = new File(Thread.currentThread().getClass().getResource("/music/08.Along_in_the_night.mp3").getPath());

InputStream fis = new FileInputStream(file);

// 生成的流

pstmt.setBinaryStream(1, fis, file.length());

// 执行SQL语句

int count = pstmt.executeUpdate();

// 处理结果

if (count > 0)

System.out.println("添加成功");

else

System.out.println("添加失败");

// 释放资源

JdbcResourceManager.close(pstmt);

JdbcResourceManager.close(conn);

JdbcSessionFactory.closeSession();

}

/**      * 从数据库中读二进制数据

*      * @throws Exception

*/

public static void read() throws Exception {

Connection conn = null;

PreparedStatement pstmt = null;

ResultSet rs = null;

// 获取数据库会话对象

JdbcSession session = JdbcSessionFactory.getCurrentSession();

// 获取数据库连接

conn = session.getConnection();

// 创建SQL语句

String sql = "SELECT id, content FROM music WHERE id=?";

// 创建PreparedStatement对象

pstmt = conn.prepareStatement(sql);

pstmt.setInt(1, 1);

// 执行SQL语句

rs = pstmt.executeQuery();

// 处理结果

if (rs.next()) {

InputStream in = rs.getBinaryStream("content");

// 获取列字段InputStream对象

// 缓冲数组

byte buf[] = new byte[1024];

int len;

// 输出流,将读取到的音乐数据保存到D盘

OutputStream out = new FileOutputStream("D:\\1.mp3");

while ((len = in.read(buf)) != -1) {

out.write(buf, 0, len);

}

in.close();

out.close();

}

// 释放资源

JdbcResourceManager.close(rs);

JdbcResourceManager.close(pstmt);

JdbcResourceManager.close(conn);

JdbcSessionFactory.closeSession();

}

public static void main(String[] args) throws Exception {

add();

read();

}

}

使用JDBC处理MySQL大文本和大数据的更多相关文章

  1. 【JDBC】Mysql海量数据插入——PreparedStatement加快数据插入

    转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/5861959.html 使用JDBC连接数据库时,如果插入的数据量大,一条一条地插入数据会变得非常缓慢.此时,我 ...

  2. 利用JDBC处理mysql大数据--大文本和二进制文件等

    转载自http://www.cnblogs.com/xdp-gacl/p/3982581.html 一.基本概念 大数据也称之为LOB(Large Objects),LOB又分为:clob和blob, ...

  3. 使用JDBC处理MySQL大数据

    一.基本概念 大数据也称之为LOB(Large Objects),LOB又分为:clob和blob,clob用于存储大文本,blob用于存储二进制数据,例如图像.声音.二进制文等. 在实际开发中,有时 ...

  4. jdbc基础 (三) 大文本、二进制数据处理

    LOB (Large Objects)   分为:CLOB和BLOB,即大文本和大二进制数据 CLOB:用于存储大文本 BLOB:用于存储二进制数据,例如图像.声音.二进制文件 在mysql中,只有B ...

  5. javaweb学习总结(三十四)——使用JDBC处理MySQL大数据

    一.基本概念 大数据也称之为LOB(Large Objects),LOB又分为:clob和blob,clob用于存储大文本,blob用于存储二进制数据,例如图像.声音.二进制文等. 在实际开发中,有时 ...

  6. javaweb(三十四)——使用JDBC处理MySQL大数据

    一.基本概念 大数据也称之为LOB(Large Objects),LOB又分为:clob和blob,clob用于存储大文本,blob用于存储二进制数据,例如图像.声音.二进制文等. 在实际开发中,有时 ...

  7. JavaWeb学习笔记(十四)—— 使用JDBC处理MySQL大数据

    一.什么是大数据 所谓大数据,就是大的字节数据,或大的字符数据.大数据也称之为LOB(Large Objects),LOB又分为:clob和blob,clob用于存储大文本,blob用于存储二进制数据 ...

  8. Mysql学习总结(13)——使用JDBC处理MySQL大数据

    一.基本概念 大数据也称之为LOB(Large Objects),LOB又分为:clob和blob,clob用于存储大文本,blob用于存储二进制数据,例如图像.声音.二进制文等. 在实际开发中,有时 ...

  9. JDBC处理mysql大数据

    大数据也称之为LOB(Large Objects),LOB又分为:clob和blob,clob用于存储大文本,blob用于存储二进制数据,例如图像.声音.二进制文等. 在实际开发中,有时是需要用程序把 ...

随机推荐

  1. org.hibernate.AnnotationException: mappedBy reference an unknown target entity property

    org.hibernate.AnnotationException: mappedBy reference an unknown target entity property: xxxxxxx 原因是 ...

  2. JAVA基础——链表结构之双端链表

    双端链表:双端链表与传统链表非常相似.只是新增了一个属性-即对最后一个链结点的引用 如上图所示:由于有着对最后一个链结点的直接引用.所以双端链表比传统链表在某些方面要方便.比如在尾部插入一个链结点.双 ...

  3. JAVA基础数组

    数组: 数组是一种容器 存储同一类型的一组数据(必须是 类型相同的一组数据) 定义数组的公式:(有两种) 1.静态定义      1)数据类型[ ] 数组名 = {元素1,元素2,元素3,元素4,元素 ...

  4. Number String(HDU 4055,动态规划递推,前缀和优化)

    点击加号查看代码 #include<bits/stdc++.h>//前缀和优化版本,不易理解 using namespace std; #define ll long long ; ; l ...

  5. tarjan求强连通分量模板

    什么是强连通分量? 百度百科 有向图强连通分量:在有向图G中,如果两个顶点vi,vj间(vi>vj)有一条从vi到vj的有向路径,同时还有一条从vj到vi的有向路径,则称两个顶点强连通(stro ...

  6. centos7修改时间和时区

    设置时区同样, 在 CentOS 7 中, 引入了一个叫 timedatectl 的设置设置程序. 用法很简单: # timedatectl # 查看系统时间方面的各种状态 Local time: 四 ...

  7. 入门系列(一) 微信小程序简介

    一.简介 1.目录结构 首先,我们使用微信公众平台提供的开发者工具,创建一个简单的小程序项目,观察项目的目录结构 不难看出,一个典型的微信小程序,通常包含一个描述整体的主体部分,以及一个描述页面的 p ...

  8. exception对象的使用及常用方法

    exception对象的使用及常用方法 制作人:全心全意 exception对象用来处理JSP文件执行时发生的所有错误和异常,只有在page指令中设置为isErrorPage属性值为true的页面中才 ...

  9. 【转】精选十二款餐饮、快递、票务行业微信小程序源码demo推荐

    微信小程序的初衷是为了线下实体业服务的,必须有实体相结合才能显示小程序的魅力.个人认为微信小程序对于餐饮业和快递业这样业务比较单一的行业比较有市场,故整理推荐12款餐饮业和快递业微信小程序源码demo ...

  10. docke容器使用

    Docker 容器使用 Docker 客户端 docker 客户端非常简单 ,我们可以直接输入 docker 命令来查看到 Docker 客户端的所有命令选项. runoob@runoob:~# do ...