mysql中clob和blob的区别有哪些

网友投稿 414 2023-11-24

mysql中clob和blob的区别有哪些

本篇内容介绍了“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),   addresstext );

插入数据

import java.io.File; import java.io.FileReader; import java.sql.Connection; importjava.sql.DriverManager;import java.sql.PreparedStatement; import java.sql.SQLException;   public class clob { /**  *@param args  */ //驱动程序就是之前在classpath中配置的JDBC的驱动程序的JAR 包中 public static finalString 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(2new 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(2new 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的区别有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:mysql如何将时分秒转换成秒数
下一篇:mysql int指的是什么
相关文章

 发表评论

暂时没有评论,来抢沙发吧~