一、mysql 中包涵的字符类型

[national] char     [(m)] [character set charset_name] [collate collation_name]
[national] varchar [(m)] [character set charset_name] [collate collation_name] binary(m) -- 和char 只不过它用来保存二进制字节串,m 指定了字节串的长度
varbinary(m) -- 和varchar 只不过它用来保存二进制字节串,m 指定了字节串的长度 tinyblob -- 使用一字节前缀,所以最多保存255个byte
blob[(m)] -- 使用二字节前缀,所以最多保存65535个byte
mediumblob -- 使用三字节前缀
longblob -- 使用四字节前缀 tinytext [character set charset_name] [collate collation_name] -- 使用一字节前缀,所以最多保存255个字符
text [character set charset_name] [collate collation_name] -- 使用二字节前缀,所以最多保存65535个字符
mediumtext [character set charset_name] [collate collation_name] -- 使用三字节前缀,所以最多保存2^24 -1个字符
longtext [character set charset_name] [collate collation_name] -- 使用四字节前缀,所以最多保存2^32 -1个字符 enum('value1','value2',...) [character set charset_name] [collate collation_name]
set('value1','value2',...) [character set charset_name] [collate collation_name]

二、char(m) 与 varchar(m) 类型

  1、char 和 varchar 之间是不同点主要表现在对值的“保存” & “检索” 。

  2、从保存说起:定义中的 m 表示所能保存的最大的字符数;如char(4) 是多能保存4个字符,varchar(4) 也是最多只保存四个字符;

  它们两的不同之处就在于varchar是按需分配的,也就是说如果你只要保存'ab'那么varchar会只为你分配两个字符的空间,

  而char它一次就会分配m个字符的空间,那怕你用不了这么多。

  3、以“检索”结尾:对于char来说没有用的的空间会以空格的方式来填充,所以检索时char会自发的去掉空格!听起来没有毛病,但是

  如果你要保存的值真的是要在最后留几个空格的呢?如果这种情况下用char的话,就会搞的存进去再拿出来就不对了。所以这个要主意。

  4、例子:由char做主键引起的血案

mysql> create table t(x char(4) not null primary key);
Query OK, 0 rows affected (0.00 sec) mysql> insert into t(x) values('a');
Query OK, 1 row affected (0.01 sec) mysql> insert into t(x) values('a '); -- 由于char会自动去掉空格,使得主键冲突了。
ERROR 1062 (23000): Duplicate entry 'a' for key 'PRIMARY'

  5、最后说一下、由于char(m)不是按需分配的,有可能会特别的占空间,所以mysql在设计时就只允许它最多保存255个字符。

三、binary 与 varbinary 类型

  1、这个就与char 和 varchar 差不多了,不同的是binary 与 varbinary 这些保存字节串。

四、blob* 与 text* 类型

  1、blob* 的全称是 binary larg object 它与binary&varbinary 相对应它们都是保存字节串的类型,只不过blob的空间更大。

  2、text* 与char&varchar 相对应它们都保存字符串。

----

学习交流

mysql string types ---- mysql 字符类型详解的更多相关文章

  1. Mysql 数据库字符类型详解

    MySQL 中提供了多种对字符数据的存储类型,不同的版本可能有所差异.以5.0 版本为例,MySQL 包括了CHAR.VARCHAR.BINARY.VARBINARY.BLOB.TEXT.ENUM 和 ...

  2. (转)MySQL字段类型详解

    MySQL字段类型详解 原文:http://www.cnblogs.com/100thMountain/p/4692842.html MySQL支持大量的列类型,它可以被分为3类:数字类型.日期和时间 ...

  3. mysql float类型详解

    mysql float类型详解float类型长度必须设置3以上 不然会报错 out of range如果设置3 就只是 整数+小数的长度 比方说3.23 3.2等等 3.333就不行了 4位了

  4. MySQL中tinytext、text、mediumtext和longtext等各个类型详解

    转: MySQL中tinytext.text.mediumtext和longtext等各个类型详解 2018年06月13日 08:55:24 youcijibi 阅读数 26900更多 个人分类: 每 ...

  5. (转)总结之:CentOS 6.5 MySQL数据库的基础以及深入详解

    总结之:CentOS 6.5 MySQL数据库的基础以及深入详解 原文:http://tanxw.blog.51cto.com/4309543/1395539 前言 早期MySQL AB公司在2009 ...

  6. MySQL数据库使用mysqldump导出数据详解

    mysqldump是mysql用于转存储数据库的实用程序.它主要产生一个SQL脚本,其中包含从头重新创建数据库所必需的命令CREATE TABLE INSERT等.接下来通过本文给大家介绍MySQL数 ...

  7. 【转】MySQL用户管理及SQL语句详解

    [转]MySQL用户管理及SQL语句详解 1.1 MySQL用户管理 1.1.1 用户的定义 用户名+主机域 mysql> select user,host,password from mysq ...

  8. MySQL数据库的各种存储引擎详解

    原文来自:MySQL数据库的各种存储引擎详解   MySQL有多种存储引擎,每种存储引擎有各自的优缺点,大家可以择优选择使用: MyISAM.InnoDB.MERGE.MEMORY(HEAP).BDB ...

  9. MYSQL之数据库初识、安装详解、sql语句基本操作

    目录 MYSQL之数据库初识及安装详解 1.什么是数据库? 1.什么是数据?(data) 2.什么是数据库?(databases,简称DB) 2.为什要用数据库? 3.什么是数据库管理系统?(Data ...

随机推荐

  1. ssl 复制

    http://www.ttlsa.com/mysql/mysql-replication-base-on-ssl/ http://www.tuicool.com/articles/mi2iaq htt ...

  2. vue头像上传与文件压缩

    工作中遇到的问题记录:vue开发头像上传组件,后端提供接口,需求为可相册上传,可相机拍摄上传,文件大小限制为2M 需求点分析 移动端调用相册/摄像头实现拍照 图片压缩,当前高像素的相机拍出来的图片都有 ...

  3. android 广告平台 keymob

    访问地址: http://www.keymob.com/

  4. Java 枚举常见7种用法

    用法一:常量 在JDK1.5 之前,我们定义常量都是: publicstaticfianl.....现在好了,有了枚举,可以把相关的常量分组到一个枚举类型里,而且枚举提供了比常量更多的方法. publ ...

  5. EventBus (二) 使用详解——EventBus使用进阶

    相关文章: 1.<EventBus使用详解(一)——初步使用EventBus> 2.<EventBus使用详解(二)——EventBus使用进阶> 一.概述 前一篇给大家装简单 ...

  6. 学习笔记 ST算法

    [引子]RMQ (Range Minimum/Maximum Query)问题: 对于长度为n的数列A,回答若干询问RMQ(A,i,j)(i,j<=n),返回数列A中下标在i,j里的最小(大)值 ...

  7. 数学图形(1.29) cochleoid曲线

    它也算是一种螺线吧 相关软件参见:数学图形可视化工具,使用自己定义语法的脚本代码生成数学图形.该软件免费开源.QQ交流群: 367752815 #http://www.mathcurve.com/co ...

  8. 解决 PowerDesigner 错误 The generation has been cancelled because errors have been found by the check model.

    在通过概念数据模型生成为物理数据模型时出现错误“The generation has been cancelled because errors have been found by the chec ...

  9. C# 怎么显示中文格式的星期几

    1.DateTime.Now.ToString("dddd",new System.Globalization.CultureInfo("zh-cn")); 2 ...

  10. 近200篇机器学习&深度学习资料分享(含各种文档,视频,源码等)(1)

    原文:http://developer.51cto.com/art/201501/464174.htm 编者按:本文收集了百来篇关于机器学习和深度学习的资料,含各种文档,视频,源码等.而且原文也会不定 ...