有一个表有上千w数据, 用什么方法给这个表加一个字段最快?
1. alert
2. 建一个表和第一个表一样,只是多了要加的字段,然后用多个insert into select语句limit写入
3. 就是导出多个文件,然后用loadfile
4. 其它?
试过2.5kw数据, alert要156m。
insert into select 100w要5m46s
两个工具选择:
http://www.percona.com/software/percona-toolkit
http://www.percona.com/doc/percona-toolkit/2.2/pt-online-schema-change.html
第二个工具是比较好的选择,可以线上改表结构,试试再给报告给大家
正在使用第二个工具,也就是facebook 针对 mysql 开源 online schema change 代码
参考文档:
http://blog.chinaunix.net/uid-53720-id-3371360.html
http://blog.csdn.net/dbanote/article/details/18261377
正在测试环境测试,测试数据量大约是2500w左右,随后有测试报告,没什么问题就上生产环境了
pt-online-schema-change --alter add category tinyint(4) not null default '0' d=库名,t=表名 -uroot -p密码 --dry-run
如果你的库有主从结构,执行上面的语句遇到如下问题:
cannot connect to d=calsync,h=从库的ip,p=...,u=root
no slaves found. see --recursion-method if host localhost.localdomain has slaves.
not checking slave lag because no slaves were found and --check-slave-lag was not specified.
请在从库上建一个root帐号且密码和上面的密码一样,且主库机可以访问
如果出现如下内容:
found 1 slaves:
localhost.localdomain
will check slave lag on:
localhost.localdomain
恭喜主从的没有问题了
bitscn.com