mysql之如何给大表加字段

 更新时间:2023年06月17日 10:27:59   作者: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;

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • MySQL8.0安装报错与密码重置全流程实战指南

    MySQL8.0安装报错与密码重置全流程实战指南

    在 Linux 服务器上部署 MySQL,本应是一项标准化、可重复的运维操作,但在实际安装 MySQL 8.0.45 及以上版本时,很多人都会遇到一条令人困惑的报错,本文将系统梳理整个问题链条,完整讲清每一个环节的底层逻辑与可执行解决方案,需要的朋友可以参考下
    2026-02-02
  • 数据从MySQL迁移到Oracle 需要注意什么

    数据从MySQL迁移到Oracle 需要注意什么

    将数据从MySQL迁移到Oracle,大家需要注意什么?Oracle移植到mysql,又需要注意什么?如何有效解决移植过程的问题,为了数据库的兼容性我们又该注意些什么?感兴趣的小伙伴们可以参考一下
    2016-11-11
  • Mysql空值处理函数详解

    Mysql空值处理函数详解

    这篇文章主要给大家介绍了关于Mysql空值处理函数的相关资料,在MySQL数据库中,空值问题是经常遇到的一个问题,空值是指在某个字段中没有数据或者数据为NULL,需要的朋友可以参考下
    2023-08-08
  • MySQL 基础常用命令总结

    MySQL 基础常用命令总结

    这篇文章主要介绍了MySQL 的基础常用命令,在执行语句的时候,很多命令都是必须记住的,想具体了解的小伙伴请参考下面文章内容
    2021-09-09
  • mysql学习笔记之表的基本操作

    mysql学习笔记之表的基本操作

    本文给大家分享的是MySQL学习笔记系列文章的入门篇,主要讲述MySQL表的基本操作命令,非常详细,有需要的小伙伴可以来查看下
    2017-02-02
  • mysql中的json查询过程

    mysql中的json查询过程

    在MySQL数据库中,进行JSON格式数据的查询时,需要使用特定函数和路径表达式来实现,本文给大家介绍mysql中的json查询过程,感兴趣的朋友一起看看吧
    2024-09-09
  • 深入解析半同步与异步的MySQL主从复制配置

    深入解析半同步与异步的MySQL主从复制配置

    这篇文章主要介绍了半同步与异步的MySQL主从复制配置,包括不同的连接方案的讨论,需要的朋友可以参考下
    2015-12-12
  • MySQL 数据库范式化设计理论总结

    MySQL 数据库范式化设计理论总结

    这篇文章主要介绍了MySQL 数据库范式设计理论总结,数据库的规划化范式设计,在逻辑结构上可以让结构更加细粒度,容易理解,下文我们就来了解具体的内容介绍吧
    2022-04-04
  • MySQL 详细单表增删改查crud语句

    MySQL 详细单表增删改查crud语句

    这篇文章主要介绍了MySQL 详细单表增删改查crud语句,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • Mysql DBA 20天速成教程

    Mysql DBA 20天速成教程

    准备一台pc,一根网线和20天无打扰的空余时间,把MySQL 5.1参考手册设置为浏览器首页,按下面列表逐条学习即可,这本中文手册包括基本上所有的内容,补充知识google也都能查到,学习平台采用linux
    2014-03-03

最新评论