当前位置: 首页 > MySQL数据库

mysql中clob和blob的区别有哪些

时间:2026-01-27 10:39:30

mysql中clob和blob的区别:1、含义不同,clob指代的是字符大对象,而blob指代的是二进制大对象;2、作用不同,clob在数据库中通常用来存储大量的文本数据,即存储字符数据,而blob用于存储二进制数据或文件,常常为图片或音频。

本教程操作环境:windows7系统、mysql8版本、Dell G3电脑。

MySQL中的blob和clob的区别

1、含义不同

clob英文全称:Character Large Object(字符大对象)

blob其全称:binary large object(二进制大对象)

估计由英文名就能想到他们的作用,所以我们记东西的时候要联想记忆,不能全靠死记硬背。

2、作用不同

clob在数据库中通常用来存储大量的文本数据,即存储字符数据。

blob用于存储二进制数据或文件,常常为图片或音频。

MySQL中的blob和clob的详解示例

clob

clob用于存储大量的文本数据。大字段的操作常常以流的方式处理。

相关类型如下:

类型最大大小
TinyText255字节
Text65535字节(约65K)
MediumText16 777 215字节(约16M)
LongText4 294 967 295 (约4G)

创建person表

CREATE TABLE person (  name varchar(20),  address text);

插入数据

import java.io.File;import java.io.FileReader;import java.sql.Connection;import java.sql.DriverManager;import java.sql.PreparedStatement;import java.sql.SQLException; public class clob {/** * @param args *///驱动程序就是之前在classpath中配置的JDBC的驱动程序的JAR 包中public static final String DBDRIVER = "com.mysql.jdbc.Driver";//连接地址是由各个数据库生产商单独提供的,所以需要单独记住public static final String DBURL = "jdbc:mysql://192.168.0.4:3306/myDB";//连接数据库的用户名public static final String DBUSER = "root";//连接数据库的密码public static final String DBPASS = "";public static void main(String[] args) throws Exception {Connection con = null; PreparedStatement stmt = null;try {//1、加载数据库驱动程序Class.forName(DBDRIVER); //2、连接数据库con = DriverManager.getConnection(DBURL,DBUSER,DBPASS); //3、创建Statement stmt = con.prepareStatement("insert into person(name,address) values(?,?)");stmt.setString(1,"April");stmt.setClob(2, new FileReader(new File("D:\\work\\info.txt")));        //4、执行SQL语句stmt.executeUpdate();}catch(SQLException e) {//5、异常处理}finally {//6、清理资源if(con !=null){con.close(); }if(stmt!=null){stmt.close();}}}}

写入也可以使用语句

stmt.setClob(2, new BufferedReader(new InputStreamReader(new ByteArrayInputStream("四川省成都市高新区".getBytes()))));

执行结果

读取数据

stmt = con.prepareStatement("select * from person");rs = stmt.executeQuery();while(rs.next()){Clob address = rs.getClob("address"); Reader reader = address.getCharacterStream(); int temp = 0;while((temp = reader.read()) != -1)  {System.out.print((char)temp);}reader.close();}

执行结果

四川省成都市高新区浙江省杭州市西湖区
blob

blob用于存储二进制数据,常常为图片或音频。

相关类型如下:

类型最大大小
TinyBlob255字节
Blob65535字节(约65K)
MediumBlob16 777 215字节(约16M)
LongBlob4 294 967 295 (约4G)

创建student表

CREATE TABLE student (  name varchar(20),  image blob);

插入数据

stmt = con.prepareStatement("insert into student(name,image) values(?,?)");stmt.setString(1,"April");stmt.setBlob(2, new FileInputStream("D:\\work\\April.png"));stmt.executeUpdate();

读取数据

stmt = con.prepareStatement("select * from student");rs = stmt.executeQuery();while(rs.next()){Blob image = rs.getBlob("image"); InputStream in = image.getBinaryStream(); OutputStream out = new FileOutputStream("D:\\work\\Harris.png");int temp = 0;while((temp = in.read()) != -1)  {out.write(temp);}in.close();out.close();}

上一篇:mysql可不可以创建联合索引
下一篇:选择mysql的原因有哪些
mysql clob blob
  • 英特尔与 Vertiv 合作开发液冷 AI 处理器
  • 英特尔第五代 Xeon CPU 来了:详细信息和行业反应
  • 由于云计算放缓引发扩张担忧,甲骨文股价暴跌
  • Web开发状况报告详细介绍可组合架构的优点
  • 如何使用 PowerShell 的 Get-Date Cmdlet 创建时间戳
  • 美光在数据中心需求增长后给出了强有力的预测
  • 2027服务器市场价值将接近1960亿美元
  • 生成式人工智能的下一步是什么?
  • 分享在外部存储上安装Ubuntu的5种方法技巧
  • 全球数据中心发展的关键考虑因素
  • 英特尔与 Vertiv 合作开发液冷 AI 处理器

    英特尔第五代 Xeon CPU 来了:详细信息和行业反应

    由于云计算放缓引发扩张担忧,甲骨文股价暴跌

    Web开发状况报告详细介绍可组合架构的优点

    如何使用 PowerShell 的 Get-Date Cmdlet 创建时间戳

    美光在数据中心需求增长后给出了强有力的预测

    2027服务器市场价值将接近1960亿美元

    生成式人工智能的下一步是什么?

    分享在外部存储上安装Ubuntu的5种方法技巧

    全球数据中心发展的关键考虑因素