「这是我参与11月更文挑战的第28天,活动详情查看:2021最后一次更文挑战」
描述
现有一张用户信息表user_info,其中包含多年来在平台注册过的用户信息。
用户信息表user_info:
请在用户信息表,字段level的后面增加一列最多可保存15个汉字的字段school;并将表中job列名改为profession,achievement的默认值设置为0。
输出结果示例:
Field | 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) | YES | ||||
profession | varchar(10) | YES | ||||
register_time | datetime | YES | CURRENT_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
字段改名为profession
,alter 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;