O MySQL possui dois tipos de campos muito similares para armazenamento de textos: o tipo TEXT e o tipo BLOB. Ambos possuem as variações TINY, MEDIUM e LONG. Assim temos TINYTEXT, TEXT, MEDIUMTEXT, LONGTEXT e também TINYBLOB, BLOB, MEDIUMBLOB e LONGBLOB. Os tipos TEXT e BLOB portanto tem apenas uma única diferença: os campos do tipo TEXT não são case-sensitive, já os campos BLOB são case-sensitive.
Vamos imaginar uma tabela chamada clientes e um campo chamado nome, com o seguinte valor:
nome -> Maria
E valos imaginar a seguinte consulta:
SELECT * FROM clientes WHERE nome = ‘maria’
Se o campo for do tipo TEXT, a consulta acima irá retornar o campo previamente definido, porém se o campo for do tipo BLOB, o campo acima não será retornado na consulta, já que campos TEXT são case-insensitive e campos BLOB são case-sensitive.
Até a próxima 😉
Muito instrutivo. Portanto, para mecanismos de busca, é melhor utilizar o tipo TEXT.
Pingback: Diferen | Analise de Sistemas
Pingback: Diferença entre os campos TEXT e BLOB do MySQL | Analise de Sistemas
Como pesquisar em campos do Tipo Blob?
Estou utilizando um campo do tipo blob para armazenar um arquivo pdf que contém textos, como pesquisar texto dentro desse arquivo pdf armazenado?
Gleison, esta busca não é possível, visto que o arquivo PDF está armazenado em formato binário no campo blob. Se você tivesse armazenado texto puro no campo blob, aí sim a busca seria possível.