DDL Schema变更之添加列有默认值时处理

对于NewSQL而言,是有表的概念的,即schema的概念。NewSQL以单独的SQL层接入用户的SQL请求,进行Parse、Logic Plan、Physical Plan,之后将对应的计划,下推到KV层进行执行。

TiDB Architecture

只要有表的存在,就会有DDL执行,TiDB的在线schema 变更参考了Google F1 Online, Asynchronous Schema Change in F1
关于这篇论文的讨论,我们放在下一篇进行分析,将结合代码一起讨论。

本篇先只讨论单机情况下,加列并存在默认值时是如何做的,我们以TiDB为例,分析如下场景。

考虑有表t1,有2列,id int primary key , age int . 并且插入2行数据:

id age
1 18
2 19

现在要加入一列,叫 marriaged_age int default 26

alter table t1 ADD marriaged_age int default 26 ;

通常,schema信息作为一个单独的Key—Value对存储在Kv层,当更新这张表的schema信息时,也就是对这个key-value的更新,我们暂时不考虑分布式场景。

id age marriaged_age
1 18 empty
2 19 empty

TiDB会将整行数据按照编码格式编码成一个字符串,作为value。key的构成格式请参考TiDB的key编码

对于存量数据,本身是没有这一列的信息的,那么就有两种做法:

  1. 给存量数据的每一行填上这一列的值
  2. 不回填这些值,当根据新的schema信息去解码value时候,发现这一列的值是empty,则用schema信息中的default值作为这一列的value。返回给上层。

TiDB采用第二种方法.

在alter table之后插入的数据,marriaged_age 这一列无论是否insert时候指定,都会有一个对应的值。

insert into t1 values(3,20);
insert into t1 values(4,22,28);

新插入的数据和旧数据如下:

id age marriaged_age
1 18 empty
2 19 empty
3 20 26
4 22 28

若这时,对marriaged_age列的default值再次进行修改时:

alter table t1 CHANGE marriaged_age marriaged_age int default 24 ;

此之后插入的数据该列的值默认值就是24了。

insert into t1 values(5,26);
insert into t1 values(6,27,30);

新插入的数据和旧数据如下:

id age marriaged_age
1 18 empty
2 19 empty
3 20 26
4 22 28
5 26 24
6 27 30

这时候,对于记录id为(1,2)的marriaged_age值,究竟应该解析成26?还是24呢?

当然是26,因为在第一次DDL变更的时候(即添加marriaged_age,就相当于已经对于存量数据做了回填,第二次变更只能对其之后的插入操作造成影响!

TiDB是如何实现这样的效果的呢?

TiDB在存Schema信息的时候,每个列的属性中,有一个 OriginalDefaultValue 和 DefaultValue

// model.go中,对列属性的描述

// ColumnInfo provides meta data describing of a table column.
type ColumnInfo struct {
    ID                  int64               `json:"id"`
    Name                CIStr               `json:"name"`
    Offset              int                 `json:"offset"`
    OriginDefaultValue  interface{}         `json:"origin_default"`
    DefaultValue        interface{}         `json:"default"`
    DefaultValueBit     []byte              `json:"default_bit"`
    GeneratedExprString string              `json:"generated_expr_string"`
    GeneratedStored     bool                `json:"generated_stored"`
    Dependences         map[string]struct{} `json:"dependences"`
    types.FieldType     `json:"type"`
    State               SchemaState `json:"state"`
    Comment             string      `json:"comment"`
    // Version means the version of the column info.
    // Version = 0: For OriginDefaultValue and DefaultValue of timestamp column will stores the default time in system time zone.
    //              That is a bug if multiple TiDB servers in different system time zone.
    // Version = 1: For OriginDefaultValue and DefaultValue of timestamp column will stores the default time in UTC time zone.
    //              This will fix bug in version 0. For compatibility with version 0, we add version field in column info struct.
    Version uint64 `json:"version"`
}

当value解码后,存在有的列是empty,那么就采用OriginDefaultValue进行填充。

OriginDefaultValue的存在就是为了保证那些在做DDL变更(这里特指ADD Column)之前的行,没有这列数据的value能够有默认值填充。

而DefaultValue就表示的是当下这列实时的default value值,以后对这列的default value 如果再有变更,那么只需要记录在DefaultValue这个变量中就可以了。

感谢磊哥(吕磊)倾情指点

萧然 2019-07-15 09:56

转载请注明出处

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,558评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,002评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,024评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,144评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,255评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,295评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,068评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,478评论 1 305
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,789评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,965评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,649评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,267评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,982评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,800评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,847评论 2 351