mysql中的本文存储(varchar char text blob)
来源:互联网 发布:java时间怎么加减 编辑:程序博客网 时间:2024/06/05 12:41
在 MySQL5.0以上的版本中,varchar数据类型的长度支持到了65535,也就是说可以存放65532个字节的数据,起始位和结束位占去了3个字 节。
字符类型若为gbk,每个字符最多占2个字节,最大长度不能超过32766;
字符类型若为utf8,每个字符最多占3个字节,最大长度不能超过21845。
若定义的时候超过上述限制,则varchar字段会被强行转为text类型,并产生warning。所以要用text或blob。
MySQL中的text和blob比较:
(1)相同
- 在TEXT或BLOB列的存储或检索过程中,不存在大小写转换,当未运行在严格模式时,如果你为BLOB或TEXT列分配一个超过该列类型的最大长度的值值,值被截取以保证适合。如果截掉的字符不是空格,将会产生一条警告。使用严格SQL模式,会产生错误,并且值将被拒绝而不是截取并给出警告.
- BLOB和TEXT列不能有 默认值.
- 当保存或检索BLOB和TEXT列的值时不删除尾部空格。(这与VARBINARY和VARCHAR列相同).
- 对于BLOB和TEXT列的索引,必须指定索引前缀的长度。对于CHAR和VARCHAR,前缀长度是可选的.
(2)相异
text :
- TEXT值是大小写不敏感的
- Text被视为非二进制字符串
- TEXT列有一个字符集,并且根据字符集的 校对规则对值进行排序和比较
- 可以将TEXT列视为VARCHAR列
- MySQL连接程序/ODBC将TEXT值定义为LONGVARCHAR
- BLOB 可以储存图片,TEXT不行,TEXT只能储存纯文本文件。4个TEXT类型TINYTEXT、TEXT、MEDIUMTEXT和LONGTEXT对应于4个BLOB类型,并且有同样的最大长度和存储需求。
blob:
- BLOB值的排序和比较以大小写敏感方式执行;
- BLOB被视为二进制字符串;
BLOB列没有字符集,并且排序和比较基于列值字节的数值值。
在大多数方面,可以将BLOB列视为能够足够大的VARBINARY列
- MySQL连接程序/ODBC将BLOB值定义为LONGVARBINARY
- 一个BLOB是一个能保存可变数量的数据的二进制的大对象。4个BLOB类型TINYBLOB、BLOB、MEDIUMBLOB和LONGBLOB仅仅在他们能保存值的最大长度方面有所不同。
(3)其他:
VARCHAR,BLOB和TEXT类型是变长类型,对于其存储需求取决于列值的实际长度(在前面的表格中用L表示),而不是取决于类型的最大可能尺寸。例如,一个VARCHAR(10)列能保存最大长度为10个字符的一个字符串,实际的存储需要是字符串的长度 ,加上1个字节以记录字符串的长度。对于字符串'abcd',L是4而存储要求是5个字节。
BLOB和TEXT类型需要1,2,3或4个字节来记录列值的长度,这取决于类型的最大可能长度。VARCHAR需要定义大小,有255的最大限制;TEXT则不需要。如果你把一个超过列类型最大长度的值赋给一个BLOB或TEXT列,值被截断以适合它。
CHAR(n) 固定长度,最多 255 个字符
VARCHAR(n) 可变长度,MySQL 4.1 及以前最大 255 字符,MySQL 5 之后最大 65535 字节
TINYTEXT 可变长度,最多 255 个字符
TEXT 可变长度,最多 65535 个字符
MEDIUMTEXT 可变长度,最多 16777215(2^24 - 1)个字符
LONGTEXT 可变长度,最多 4294967295(2^32 - 1)(4G)个字符
- mysql中的本文存储(varchar char text blob)
- MySql中的CHAR、VARCHAR、TEXT与BLOB类型
- mysql char varchar blob text性能详解
- MYSQL中CHAR,VARCHAR,BLOB和TEXT的比较
- MySql中的CHAR、VARCHAR、TEXT选用
- mysql中char、varchar、text区别和存储范围
- MySQl之char,varchar,text
- mysql数据库text、varchar、blob数据类型比较
- MySQL数据类型char、varchar、text的比较
- mysql char varchar text的区别
- mysql中char,varchar,text区别
- mysql中char,varchar,text区别
- mysql char,varchar与text的选择
- 【MySQL进阶】--char & varchar & text的区别
- MySQL 字段类型varchar,CHAR,text
- Mysql 中 char 、varchar 、text的区别
- mysql之char、varchar和text
- Mysql 中 char 、varchar 、text的区别
- 云计算的应用有哪些
- StackExchange.Redis官方文档(二)【配置】
- Java中二叉树面试题
- Android 开发中比较常见的5个内存泄漏问题及解决办法
- js中的原始值是什么?
- mysql中的本文存储(varchar char text blob)
- ORACLE 查询字表未明确定义列
- AlphaGo zero 概述和引言翻译
- CDN缓存小结
- 设计模式讲解与代码实践(二十)——观察者
- Execution failed for task ':app:transformClassesWithDexForRelease'.
- Android Retrofit2使用
- spring boot打jar包遇到错误
- ubuntu部署php7.1