What are the differences between the BLOB and TEXT datatypes in MySQL?
Asked Answered
C

6

141

What is blob and what is text? What are the differences?

When do I need to use blob and when do I need text as data type?

Because for blob and text, there are mediumblob == mediumtext, smallblob == small text. Do they even have the same meaning?

And look at this MEDIUMBLOB, MEDIUMTEXT L + 3 bytes, where L < 224.

What is L?

Chancellorsville answered 24/7, 2012 at 5:42 Comment(1)
I think this post answers your question https://mcmap.net/q/167895/-mysql-text-vs-blob-vs-clobGraber
R
125

TEXT and CHAR will convert to/from the character set they have associated with time. BLOB and BINARY simply store bytes.

BLOB is used for storing binary data while Text is used to store large string.

BLOB values are treated as binary strings (byte strings). They have no character set, and sorting and comparison are based on the numeric values of the bytes in column values.

TEXT values are treated as nonbinary strings (character strings). They have a character set, and values are sorted and compared based on the collation of the character set.

http://dev.mysql.com/doc/refman/5.0/en/blob.html

Rehabilitation answered 24/7, 2012 at 5:45 Comment(6)
so, we use text to store long text such as "wordpress post" ? and we use blob to store a very long URL addresses ? so why don't we use varchar to store a very long text instead of using blob or text ? because in memory calculating, varchar is really simple, for example create table website( website_name varchar(30) ) and then we fill the website_name "stackoverflow" so the memory needed is 13byteChancellorsville
TEXT is going to be replaced with Varchar(MAX) but for now depending on your version of mysql use TEXT for large text posts such as blog body posts etc. BLOB shouldn't be used for storing very long URL addresses or large amounts of text. It's normally used to store images or other binary based objects. Personally I never use BLOB or TEXT and store large amounts of data in xml files relative to user id based folders.Rehabilitation
i don't understand binary based object. you mean, we can store photo to database using Blob data type ?? just like folder ? all that i know about binary is only 1 or 0.Chancellorsville
@Chancellorsville Yes, you can store images to databases. You can also store archives. But you cannot store a folder to a database, because folders are actually features of the file system. (You could eventually store a complete file system e.g. as an iso file to a database, though)Futtock
@martin-thoma We have an application where the Server-Side has a MongoDB database. The Mobile Component of the application uses SQLLite. There needs to be a way to bridge data between the MongoDB Database and the SQLLite Database. MongoDB use ObjectIds to identify data uniquely. Since the SQLLite (RDBMS world ) does Not have any direct way of representing MongoDB ObjectIds, I was wondering if I could store ObjectIds as BLOB types. Does that sound like a reasonably solution? Would it slow performance? Would there be any other Drawbacks?Nalchik
BLOB values are treated as binary strings (byte strings). They have the binary character set and collation, and comparison and sorting are based on the numeric values of the bytes in column values. dev.mysql.com/doc/refman/8.0/en/blob.htmlWaldner
P
16

Blob datatypes stores binary objects like images while text datatypes stores text objects like articles of webpages

Plastic answered 16/3, 2015 at 19:6 Comment(0)
A
10

TEXT and CHAR or nchar that will typically be converted to plain text so you can only store text like strings.

BLOB and BINARY which mean you can store binary data such as images simply store bytes.

Annihilation answered 24/7, 2012 at 5:46 Comment(2)
what do you mean by store binary data such as image ? did you mean image url ?Chancellorsville
No, the actual image .Mosque
B
8

A BLOB is a binary string to hold a variable amount of data. For the most part BLOB's are used to hold the actual image binary instead of the path and file info. Text is for large amounts of string characters. Normally a blog or news article would constitute to a TEXT field

L in this case is used stating the storage requirement. (Length|Size + 3) as long as it is less than 224.

Reference: http://dev.mysql.com/doc/refman/5.0/en/blob.html

Billbillabong answered 24/7, 2012 at 5:46 Comment(0)
F
7

According to High-performance Mysql book:

The only difference between the BLOB and TEXT families is that BLOB types store binary data with no collation or character set, but TEXT types have a character set and collation.

Faradism answered 14/10, 2018 at 20:31 Comment(0)
S
1

BLOB stores binary data which are more than 2 GB. Max size for BLOB is 4 GB. Binary data means unstructured data i.e images audio files vedio files digital signature

Text is used to store large string.

Shimmy answered 21/1, 2019 at 9:56 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.