SQL之修改表

1、知识点简介

增加列在某列之后:
alter table 增加的表格 add 增加列的名称 数据类型 位置(after level 在level 之后)
alter table user_info add school varchar(15) after level;


更换列的名称及数据类型:
alter table user_info change 原列名 修改列名 修改数据类型
alter table user_info change job profession varchar(10);


更改数据类型:
alter table 表名 modify 修改列名称 数据类型 默认值等
alter table user_info modify achievement int(11) default 0;

2、案例

现有一张用户信息表user_info,其中包含多年来在平台注册过的用户信息。

用户信息表user_info:

Filed Type Null Key Default Extra Comment
id int(11) NO PRI (NULL) auto_increment 自增ID
uid int(11) NO UNI (NULL) 用户ID
nick_name varchar(64) YES (NULL) 昵称
achievement int(11) YES 0 成就值
level int(11) YES (NULL) 用户等级
job varchar(32) YES (NULL) 职业方向
register_time datetime YES CURRENT_TIMESTAMP 注册时间

请在用户信息表,字段level的后面增加一列最多可保存15个汉字的字段school;并将表中job列名改为profession,同时varchar字段长度变为10;achievement的默认值设置为0。

alter table user_info add school varchar(15) after level;
alter table user_info change job profession varchar(10);
alter table user_info modify achievement int(11) Default 0;

输出结果示例:

Filed Type Null Key Default Extra Comment
id int(11) NO PRI auto_increment 自增ID
uid int(11) NO UNI 用户ID
nick_name varchar(64) YES 昵称
achievement int(11) YES 0
level int(11) YES 用户等级
school varchar(15)
profession varchar(10) YES
register_time datetime YES CURRENT_TIMESTAMP 注册时间

备注:建表时限制的字符集为utf8,MySQL版本为8.*

后台会通过SHOW FULL FIELDS FROM user_info 来对比输出结果。

猜你喜欢

转载自blog.csdn.net/weixin_48272780/article/details/128329160
今日推荐