但是一个表刚做了set column unused的 *** 作.所以无法交换.
把unused columns drop掉之后,就正常了
MySQL: 5.7.25-log
1.生成列语法:
2.生成列支持两种创建方式,分别对应关键词 VIRTUAL 和 STORED:
3.其他:
1.不指定关键字时候默认为 VIRTUAL生成列
2.VIRTUAL不占用存储空间,STORED占用存储空间
向三表插入相同的大量数据,然后查询表空间文件大小如下:
3.一个表中可以既包含 VIRTUAL 列,又包含 STORED 列
4.可指定列是否为NULL,是否唯一索引,是否二级索引,是否有COMMENTS(选择部分测试),但不能使用auto_increment属性
5.STORED生成列可指定是否主键,VIRTUAL生成列不支持
6.不支持不确定性函数
7.可基于生成列再创建生成列,但有先后顺序,基于基础列便无先后顺序
8.CREATE TABLE ... LIKE 建表,目标表会保留源表的生成列信息
9.CREATE TABLE ... AS SELECT 建表,不复制生成列信息
10.支持基于生成列创建分区表
11.不论是表还是视图,显示更新生成列时仅支持值 DEFAULT
11.基于json字段建 生成列+索引
12.使用生成列的表达式进行查询亦可走索引,但条件苛刻
还有一些限制及特性,就不一一列举了。
https://dev.mysql.com/doc/refman/5.7/en/create-table-generated-columns.html
https://dev.mysql.com/doc/refman/5.7/en/create-table-secondary-indexes.html
https://dev.mysql.com/doc/refman/5.7/en/generated-column-index-optimizations.html
本文主要展示如何使用mysql的多列组合查询
多列组合查询平常比较少见,初次看还觉得挺神奇的。
• mysql-filtering-by-multiple-columns[1]
• selecting-where-two-columns-are-in-a-set[2]
[1] mysql-filtering-by-multiple-columns https://www.tutorialspoint.com/mysql-filtering-by-multiple-columns
[2] selecting-where-two-columns-are-in-a-set https://dba.stackexchange.com/questions/34266/selecting-where-two-columns-are-in-a-set
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)