加入收藏 | 设为首页 | 会员中心 | 我要投稿 银川站长网 (https://www.0951zz.com/)- 云通信、基础存储、云上网络、机器学习、视觉智能!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

mysql中clob和blob的差异有哪些

发布时间:2023-05-26 13:34:58 所属栏目:MySql教程 来源:
导读:本篇内容介绍了“mysql中clob和blob的区别有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

本篇内容介绍了“mysql中clob和blob的区别有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

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中clob和blob的区别有哪些”的内容就介绍到这里了,感谢大家的阅读。

(编辑:银川站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!