牛客SQL.2.10

123 阅读2分钟

「这是我参与11月更文挑战的第28天,活动详情查看:2021最后一次更文挑战

描述

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

用户信息表user_info:

img

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

输出结果示例:

FieldTypeNullKeyDefaultExtraComment
idint(11)NOPRIauto_increment自增ID
uidint(11)NOUNI用户ID
nick_namevarchar(64)YES昵称
achievementint(11)YES0
levelint(11)YES用户等级
schoolvarchar(15)YES
professionvarchar(10)YES
register_timedatetimeYESCURRENT_TIMESTAMP注册时间

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

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

示例1

drop table if exists user_info;
CREATE TABLE IF NOT EXISTS user_info (
id int PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
uid int UNIQUE NOT NULL COMMENT '用户ID',
`nick_name` varchar(64) COMMENT '昵称',
achievement int COMMENT '成就值',
level int COMMENT '用户等级',
job varchar(10) COMMENT '职业方向',
register_time datetime DEFAULT CURRENT_TIMESTAMP COMMENT '注册时间'
)CHARACTER SET utf8 COLLATE utf8_general_ci;
id|int|None|NO|PRI|None|auto_increment|select,insert,update,references|自增ID
uid|int|None|NO|UNI|None||select,insert,update,references|用户ID
nick_name|varchar(64)|utf8_general_ci|YES||None||select,insert,update,references|昵称
achievement|int|None|YES||0||select,insert,update,references|
level|int|None|YES||None||select,insert,update,references|用户等级
school|varchar(15)|utf8_general_ci|YES||None||select,insert,update,references|
profession|varchar(10)|utf8_general_ci|YES||None||select,insert,update,references|
register_time|datetime|None|YES||CURRENT_TIMESTAMP|DEFAULT_GENERATED|select,insert,update,references|注册时间

方法一

根据题意来修改表结构;

  • 在字段level后面添加一个字段school,默认添加一行列的语句是表示在所有列之后添加,如果想在指定列后面添加则要使用after xxx(指定列名),如果是在最开始添加,则在最后使用first即可。

ALTER TABLE user_info ADD COLUMN school VARCHAR(15) AFTER level;

  • job字段改名为professionalter table 表名 change column 旧列名 新列名 类型;

ALTER TABLE user_info CHANGE job profession VARCHAR(10);

  • achievement字段的默认值改为0,alter table 表名 modify 修改列名称 数据类型 默认值等

ALTER TABLE user_info MODIFY achievement int(11) DEFAULT 0;