赞
踩
表的创建、修改与删除:
CREATE TABLE [IF NOT EXISTS] tb_name -- 不存在才创建,存在就跳过 (column_name1 data_type1 -- 列名和类型必选 [ PRIMARY KEY -- 可选的约束,主键 | FOREIGN KEY -- 外键,引用其他表的键值 | AUTO_INCREMENT -- 自增ID | COMMENT comment -- 列注释(评论) | DEFAULT default_value -- 默认值 | UNIQUE -- 唯一性约束,不允许两条记录该列值相同 | NOT NULL -- 该列非空 ], ... ) [CHARACTER SET charset] -- 字符集编码 [COLLATE collate_value] -- 列排序和比较时的规则(是否区分大小写等) |
1.2 从另一张表复制表结构创建表: CREATE TABLE tb_name LIKE tb_name_old
1.3 从另一张表的查询结果创建表: CREATE TABLE tb_name AS SELECT * FROM tb_name_old WHERE options
2.1 修改表:ALTER TABLE 表名 修改选项
。选项集合:
1 2 3 4 5 6 7 8 | { ADD COLUMN <列名> <类型> -- 增加列 | CHANGE COLUMN <旧列名> <新列名> <新列类型> -- 修改列名或类型 | ALTER COLUMN <列名> { SET DEFAULT <默认值> | DROP DEFAULT } -- 修改/删除 列的默认值 | MODIFY COLUMN <列名> <类型> -- 修改列类型 | DROP COLUMN <列名> -- 删除列 | RENAME TO <新表名> -- 修改表名 | CHARACTER SET <字符集名> -- 修改字符集 | COLLATE <校对规则名> } -- 修改校对规则(比较和排序时用到) |
(1)现有一张用户信息表,其中包含多年来在平台注册过的用户信息,随着牛客平台的不断壮大,用户量飞速增长,为了高效地为高活跃用户提供服务,现需要将部分用户拆分出一张新表。
原来的用户信息表:
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 | 注册时间 |
作为数据分析师,请创建一张优质用户信息表user_info_vip,表结构和用户信息表一致。
- --T1:
- CREATE TABLE IF NOT EXISTS user_info_vip
- (id int PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
- uid int UNIQUE NOT NULL COMMENT '用户ID',
- nick_name varchar(64) COMMENT '昵称',
- achievement int DEFAULT 0 COMMENT '成就值',
- `level` int COMMENT '用户等级',
- job varchar(32) COMMENT '职业方向',
- register_time datetime DEFAULT CURRENT_TIMESTAMP COMMENT '注册时间')
- CHARACTER SET utf8 COLLATE utf8_general_ci;
-
- --T2:
- create table user_info_vip(
- id int(11) not null primary key auto_increment comment '自增ID',
- uid int(11) not null unique key comment '用户ID',
- nick_name varchar(64) comment '昵称',
- achievement int(11) default 0 comment '成就值',
- level int(11) comment '用户等级',
- job varchar(32) comment '职业方向',
- register_time datetime default current_timestamp comment '注册时间'
- ) default charset=utf8
你应该返回的输出如下表格所示,请写出建表语句将表格中所有限制和说明记录到表里。
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 | 用户等级 | |||
job | varchar(32) | YES | 职业方向 | |||
register_time | datetime | YES | CURRENT_TIMESTAMP | 注册时间 |
备注:
1.后台会通过 SHOW FULL FIELDS FROM user_info_vip 语句,来对比输出结果
2.如果该表已经被其他分析师创建过了,正常返回即可。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。