mysql行格式怎么用 mysql怎么换行( 七 )


六、位类型
bit 为 MySQL 里存储比特位的类型,最大支持 64 比特位, 直接以二进制方式存储,一般用来存储状态类的信息 。比如,性别,真假等 。具有以下特性:
1. 对于 bit(8) 如果单纯存放 1 位,左边以 0 填充 00000001 。2. 查询时可以直接十进制来过滤数据 。3. 如果此字段加上索引,MySQL 不会自己做类型转换 , 只能用二进制来过滤 。
示例 7
创建表 c1, 字段性别定义一个比特位 。mysql-(ytt/3305)-create table c1(gender bit(1));Query OK, 0 rows affected (0.02 sec)
mysql-(ytt/3305)-select cast(gender as unsigned)'f1' from c1;+------+| f1|+------+|0 ||1 |+------+2 rows in set (0.00 sec)
过滤数据也一样,二进制或者直接十进制都行 。mysql-(ytt/3305)-select conv(gender,16,10) as gender \- from c1 where gender = b'1'; +--------+| gender |+--------+| 1|+--------+1 row in set (0.00 sec)mysql-(ytt/3305)-select conv(gender,16,10) as gender \- from c1 where gender = '1';+--------+| gender |+--------+| 1|+--------+1 row in set (0.00 sec)
其实这样的场景,也可以定义为 char(0),这也是类似于 bit 非常优化的一种用法 。
mysql-(ytt/3305)-create table c2(gender char(0));Query OK, 0 rows affected (0.03 sec)
那现在我给表 c1 简单的造点测试数据 。
mysql-(ytt/3305)-select count(*) from c1;+----------+| count(*) |+----------+| 33554432 |+----------+1 row in set (1.37 sec)
把 c1 的数据全部插入 c2 。
mysql-(ytt/3305)-insert into c2 select if(gender = 0,'',null) from c1;Query OK, 33554432 rows affected (2 min 18.80 sec)Records: 33554432Duplicates: 0Warnings: 0
两张表的磁盘占用差不多 。root@ytt-pc:/var/lib/mysql/3305/ytt# ls -sihl总用量 1.9G4085684 933M -rw-r----- 1 mysql mysql 932M 12月 11 10:16 c1.ibd4082686 917M -rw-r----- 1 mysql mysql 916M 12月 11 10:22 c2.ibd
检索方式稍微有些不同,不过效率也差不多 。所以说,字符类型不愧为万能类型 。
七、枚举类型
枚举类型,也即 enum 。适合提前规划好了所有已经知道的值,且未来最好不要加新值的情形 。枚举类型有以下特性:
1. 最大占用 2 Byte 。2. 最大支持 65535 个不同元素 。3. MySQL 后台存储以下标的方式 , 也就是 tinyint 或者 smallint 的方式,下标从 1 开始 。4. 排序时按照下标排序,而不是按照里面元素的数据类型 。所以这点要格外注意 。
示例 8
创建表 t7 。mysql-(ytt/3305)-create table t7(c1 enum('mysql','oracle','dble','postgresql','mongodb','redis','db2','sql server'));Query OK, 0 rows affected (0.03 sec)
八、集合类型
集合类型 SET 和枚举类似,也是得提前知道有多少个元素 。SET 有以下特点:
1. 最大占用 8 Byte,int64 。2. 内部以二进制位的方式存储,对应的下标如果以十进制来看,就分别为 1,2,4,8 , ...,pow(2,63) 。3. 最大支持 64 个不同的元素,重复元素的插入,取出来直接去重 。4. 元素之间可以组合插入,比如下标为 1 和 2 的可以一起插入,直接插入 3 即可 。
示例 9
定义表 c7 字段 c1 为 set 类型 , 包含了 8 个值,也就是下表最大为 pow(2,7) 。
mysql-(ytt/3305)-create table c7(c1 set('mysql','oracle','dble','postgresql','mongodb','redis','db2','sql server'));Query OK, 0 rows affected (0.02 sec)
插入 1 到 128 的所有组合 。
mysql-(ytt/3305)-INSERT INTO c7WITH RECURSIVE ytt_number (cnt) AS (SELECT 1 AS cntUNION ALLSELECT cnt + 1FROM ytt_numberWHERE cntpow(2, 7))SELECT *FROM ytt_number;Query OK, 128 rows affected (0.01 sec)Records: 128Duplicates: 0Warnings: 0
九、数据类型在存储函数中的用法
函数里除了显式声明的变量外,默认 session 变量的数据类型很弱 , 随着给定值的不同随意转换 。
示例 10

推荐阅读