mysql之如何给大表加字段
作者:shmily&&ylimhs
这篇文章主要介绍了mysql之如何给大表加字段问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
mysql给大表加字段
方法1.
直接添加字段(在数据量比较小的情况下操作,可能会造成表死锁)
ALTER TABLE 表名 ADD 字段名 字段属性 DEFAULT '有默认值或者允许为null' COMMENT '字段解释' ;
方法适合十几万的数据量,可以直接进行加字段操作,但是,线上的一张表如果数据量很大,执行加字段操作就会锁表,这个过程可能需要很长时间甚至导致服务崩溃(俗称表锁),那么这样操作就有风险。
如果服务崩溃时,可通过show PROCESSLIST找到对应info列(之前执行的SQL语句)以及state列为locked的id值,然后kill id对应的值就可以了
方法2.
创建一张临时的新表
3. ① 创建一个临时的新表,首先复制旧表的结构(包含索引);
create table 临时表 like 旧表;
② 给新表加上新增的字段
alter table student_log1 add zyp int(11) null DEFAULT 0
注:新增字段要么有为空,要么有默认,否则后续复制表报错
③ 复制旧表数据到新表,注意此时新表是空表,加字段很快;
INSERT INTO student_log1 ( id, NAME, sno, ip, url, operation, excute_time ) SELECT id, NAME, sno, ip, url, operation, excute_time FROM student_log
注:复制表数据最好在业务低峰期操作,避免数据丢失
④ 删除旧表(可以先把旧表重命名,不建议立即删除,方便后续的数据恢复,如果确保复制表数据成功,可以删除旧表),重命名新表的名字为旧表的名字
alter table student_log1 rename to student_log;
mysql给表和字段添加注释
在MySQL中,给表和字段添加注释使用COMMENT关键字。
1、添加表和字段的注释
创建数据表的同时,给表和字段添加注释。
-- 创建用户信息表 CREATE TABLE tb_user ( id INT AUTO_INCREMENT PRIMARY KEY COMMENT '编号', name VARCHAR(30) COMMENT '姓名' )COMMENT = '用户信息表';
2、修改表注释
ALTER TABLE tb_user COMMENT '用户信息表2';
3、修改字段注释
修改字段备注,其实就是修改字段的定义。
ALTER TABLE tb_user MODIFY COLUMN name VARCHAR(30) NOT NULL COMMENT '姓名2';
**注意:**修改时要把该字段的完整定义写上,如字段类型、属性等。
千万不要因为只是为了修改一个注释,而把该字段定义的其它属性给覆盖掉了。
4、查询字段信息
SHOW FULL COLUMNS FROM tb_user;
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。