MySQL生成列(Generated Columns)

MySQL生成列(Generated Columns),第1张

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

1、先用Navicat for MySQL创建名字为shopping的数据库,如下图所示:

2、创建的shopping数据库上运行已有的.sql文件,要注意上面创建的数据库名字shopping最好和原先.sql文件中的名字一样,也可以不一样,如果不一样的话会自动生成原来.sql文件中SQL语句中所命名的数据库。

Mysql:MySQL 是一个关系型数据库,由瑞典 MySQL AB 公司开发,目前属于 Oracle 旗下公司。MySQL 最流行的关系型数据库管理系统,在 WEB 应用方面 MySQL 是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件之一。

MySQL 是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。MySQL 所使用的 SQL 语言是用于访问数据库的最常用标准化语言。

MySQL 软件采用了双授权政策(本词条"授权政策"),它分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择 MySQL 作为网站数据库。由于其社区版的性能卓越,搭配 PHP ,Linux和 Apache 可组成良好的开发环境,经过多年的web技术发展,在业内被广泛使用的一种web服务器解决方案之一,称之为LAMP。

1 mysql 的存储过程里,没有固定的输出语句,要输出内容,使用 select .. 形式即可;

select var_a

select column_a from tb_a limit 2

2 存储过程里,如果只是输出内容(不进行捕获),用上边1中的select即可;如果调用存储过程后对输出的值进行后续捕获,则需使用 out 指定输出参数;

3 @var_a 表示这是个会话变量,在存储过程里可以直接设置值而不用声明,如

set @var_a = 10

但并不推荐在存储过程里使用会话变量(因为这种变量在同一个mysql连接是都是生效的,执行完存储后仍存在),推荐使用声明式的临时变量,即以下方式:

declare var_a int

set var_a = 10

4 示例

drop PROCEDURE p_a

create PROCEDURE p_a(out aa int)

begin

declare bb int

set bb = 10

select bb

select * from t_student limit 1

select CURRENT_DATE()

set aa = bb

end

#调用

set @temp = 50

call p_a(@temp)

select @temp #@temp 为会话变量,由存储过程返回重设值了。

希望能解决您的问题。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/8549507.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-17
下一篇2023-04-17

发表评论

登录后才能评论

评论列表(0条)

    保存