创建、修改、删除表
表的创建、修改与删除:
- 1.1 直接创建表:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
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] -- 列排序和比较时的规则(是否区分大小写等) |
create table if not exists user_info_vip( id int(11) not null auto_increment comment '自增ID', uid int(11) not null 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 '注册时间', primary key(`id`), unique index(`uid`) )comment '用户信息表'
-
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 <校对规则名> } -- 修改校对规则(比较和排序时用到) |
alter table user_info add school varchar(15) after level; 增加列在某列之后 alter table 增加的表格 add 增加列的名称 数据类型 位置(after level 在level 之后) alter table user_info change job profession varchar(10); 更换列的名称及数据类型 alter table user_info change 原列名 修改列名 修改数据类型 alter table user_info modify achievement int(11) default 0; 更改数据类型 alter table 表名 modify 修改列名称 数据类型 默认值等
- 3.1 删除表:
DROP TABLE [IF EXISTS] 表名1 [ ,表名2]
。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通