mysql里乘号怎么 mysql乘法运算符( 二 )


综上所述,日期这块类型的选择遵循以下原则:
1. 如果时间有可能超过时间戳范围 , 优先选择 datetime 。2. 如果需要单独获取年份值,比如按照年来分区,按照年来检索等,最好在表中添加一个 year 类型来参与 。3. 如果需要单独获取日期或者时间,最好是单独存放,而不是简单的用 datetime 或者 timestamp 。后面检索时,再加函数过滤,以免后期增加 SQL 编写带来额外消耗 。
4. 如果有保存毫秒类似的需求 , 最好是用时间类型自己的特性,不要直接用字符类型来代替 。MySQL 内部的类型转换对资源额外的消耗也是需要考虑的 。
示例 5
建立表 t5,对这些可能需要的字段全部分离开,这样以后写 SQL 语句的时候就很容易了 。
当然了 , 这种情形占用额外的磁盘空间 。如果想在易用性与空间占用量大这两点来折中,可以用 MySQL 的虚拟列来实时计算 。比如假设 c5 字段不存在 , 想要得到 c5 的结果 。mysql-(ytt/3305)-alter table t5 drop c5, add c5 year generated always as (year(c1)) virtual;Query OK, 1 row affected (2.46 sec)Records: 1Duplicates: 0Warnings: 0
五、二进制类型
binary 和 varbinary 对应了 char 和 varchar 的二进制存储 , 相关的特性都一样 。不同的有以下几点:
binary(10)/varbinary(10) 代表的不是字符个数,而是字节数 。
行结束符不一样 。char 的行结束符是 \0,binary 的行结束符是 0x00 。
由于是二进制存储,所以字符编码以及排序规则这类就直接无效了 。
示例 6
来看这个 binary 存取的简单示例,还是之前的变量 @a 。
切记!这里要提前计算好 @a 占用的字节数,以防存储溢出 。
六、位类型
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 。适合提前规划好了所有已经知道的值,且未来最好不要加新值的情形 。枚举类型有以下特性:

推荐阅读