MariaDB扩展特性--虚拟列

存在于表中的列,它们的值是根据确定的表达式或者是根据表中其他列的值自动计算的。
虚拟列有两种,分别对应了定义虚拟列的修饰关键词:
‘VIRTUAL’修饰词含义为该虚拟列的值会在查询的时候计算生成。
‘PERSISTENT’修饰词含义为该虚拟列的值存储子表中。
create table example_vc_tbl(
c1 int not null auto_increment primary key,
c2 varchar(70),
vc1 int as (length(c2)) virtual,
vc2 varchar(10) as (left(c2,10)) persistent
);

MariaDB [test]> desc example_vc_tbl;
+-------+-------------+------+-----+---------+----------------+
| Field | Type        | Null | Key | Default | Extra          |
+-------+-------------+------+-----+---------+----------------+
| c1    | int(11)     | NO   | PRI | NULL    | auto_increment |
| c2    | varchar(70) | YES  |     | NULL    |                |
| vc1   | int(11)     | YES  |     | NULL    | VIRTUAL        |
| vc2   | varchar(10) | YES  |     | NULL    | PERSISTENT     |
+-------+-------------+------+-----+---------+----------------+
4 rows in set (0.01 sec)

在执行插入操作时,虚拟列使用default关键字代替。 

MariaDB [test]> insert into example_vc_tbl(c2,vc1,vc2) values('你说你双休日不去泡妞还在电脑前做什么?',default,default);
Query OK, 1 row affected (0.01 sec)

MariaDB [test]> select * from example_vc_tbl;
+----+-----------------------------------------------------------+------+--------------------------------+
| c1 | c2                                                        | vc1  | vc2                            |
+----+-----------------------------------------------------------+------+--------------------------------+
|  1 | 你说你双休日不去泡妞还在电脑前做什么?                    |   57 | 你说你双休日不去泡妞           |
+----+-----------------------------------------------------------+------+--------------------------------+
1 row in set (0.00 sec)

转载于:https://my.oschina.net/liuliufa/blog/661106

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值