在mysql中有两个字段类型容易让人感觉混淆,那就是text与blob,特别是自己写博客程序的博主不知道改为自己的博客正文字段选择text还是blob类型。
下面给出几点区别:
一、主要差别
text与blob的主要差别就是blob保存二进制数据,text保存字符数据。目前几乎所有博客内容里的图片都不是以二进制存储在数据库的,而是把图片上传到服务器然后正文里使用标签引用,这样的博客就可以使用text类型。而blob就可以把图片换算成二进制保存到数据库中。
二、类型区别
blob有4种类型:tinyblob、blob、mediumblob和longblob。它们只是可容纳值的最大长度不同。
text也有4种类型:tinytext、text、mediumtext和longtext。这些类型同blob类型一样,有相同的最大长度和存储需求。
三、字符集
blob列没有字符集,并且排序和比较基于列值字节的数值值。text列有一个字符集,并且根据字符集的校对规则对值进行排序和比较
四、大小写
在text或blob列的存储或检索过程中,不存在大小写转换,都一样!
五、严格模式
运行在非严格模式时,如果你为blob或text列分配一个超过该列类型的最大长度的值值,值被截取以保证适合。如果截掉的字符不是空格,将会产生一条警告。使用严格sql模式,会产生错误,并且值将被拒绝而不是截取并给出警告。
六、其它
当保存或检索blob和text列的值时不删除尾部空格。
对于blob和text列的索引,必须指定索引前缀的长度。
blob和text列不能有默认值。
当排序时只使用该列的前max_sort_length个字节。max_sort_length的 默认值是1024。
当你想要使超过max_sort_length的字节有意义,对含长值的blob或text列使用group by或order by的另一种方式是将列值转换为固定长度的对象。标准方法是使用substring函数。
blob或text对象的最大大小由其类型确定,但在客户端和服务器之间实际可以传递的最大值由可用内存数量和通信缓存区大小确定。你可以通过更改max_allowed_packet变量的值更改消息缓存区的大小,但必须同时修改服务器和客户端程序。
0
0
相关文章
mysql语法错误一直报错怎么办_mysql基础异常处理
mysql数据类型错误怎么修复_mysql字段异常处理
如何配置mysql权限表_mysql权限表初始化方法
如何用mysql开发问卷调查系统_mysql问卷调查数据库搭建方法
mysql触发器能否跨表操作_mysql使用限制解析
相关标签:
本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门AI工具
相关专题
想找真正自由、无限制的上网体验?本合集精选2025年最开放、隐私强、访问无阻的浏览器App,涵盖Tor、Brave、Via、X浏览器、Mullvad等高自由度工具。支持自定义搜索引擎、广告拦截、隐身模式及全球网站无障碍访问,部分更具备防追踪、去谷歌化、双内核切换等高级功能。无论日常浏览、隐私保护还是突破地域限制,总有一款适合你!
7
2025.12.31
想让网页流畅播放视频?本合集详解HTML5视频播放核心方法!涵盖<video>标签基础用法、多格式兼容(MP4/WebM/OGV)、自定义播放控件、响应式适配及常见浏览器兼容问题解决方案。无需插件,纯前端实现高清视频嵌入,助你快速打造现代化网页视频体验。
4
2025.12.31
想快速上手HTML5开发?本合集为你整理最实用的HTML5使用指南!涵盖HTML5基础语法、主流框架(如Bootstrap、Vue、React)集成方法,以及无需安装、直接在线编辑运行的平台推荐(如CodePen、JSFiddle)。无论你是新手还是进阶开发者,都能轻松掌握HTML5网页制作、响应式布局与交互功能开发,零配置开启高效前端编程之旅!
2
2025.12.31
热门下载
相关下载
精品课程







