SQL创建新表

表的创建、修改与删除:

复制代码
1.1 直接创建表:

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 表名 修改选项 。选项集合: { ADD COLUMN \<列名\> \<类型\> 【first\|after 字段名】-- 增加列 \| CHANGE COLUMN \<旧列名\> \<新列名\> \<新列类型\> -- 修改列名或类型 \| ALTER COLUMN \<列名\> { SET DEFAULT \<默认值\> \| DROP DEFAULT } -- 修改/删除 列的默认值 \| MODIFY COLUMN \<列名\> \<类型\> -- 修改列类型 \| DROP COLUMN \<列名\> -- 删除列 \| RENAME TO \<新表名\> -- 修改表名 \| CHARACTER SET \<字符集名\> -- 修改字符集 \| COLLATE \<校对规则名\> } -- 修改校对规则(比较和排序时用到) > 建议:修改列属性时使用modify;修改列名使用change。 > > 删除表之后重建表 > > drop table if exists 表名; > > create table if not exists 表名...; 3.1 删除表:DROP TABLE [IF EXISTS] 表名1 [ ,表名2]。 细节剖析: 自增ID:AUTO_INCREMENT; 设置主键:PRIMARY KEY; 唯一性约束:UNIQUE 非空约束:NOT NULL 设置默认值:DEFAULT 0 当前时间戳:CURRENT_TIMESTAMP 评论/注释:COMMENT 如果该表已创建过,正常返回:IF NOT EXISTS 示例: ```sql 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; ```

相关推荐
随风飘的云3 小时前
MySQL的慢查询优化解决思路
数据库
IvorySQL7 小时前
PostgreSQL 技术日报 (3月7日)|生态更新与内核性能讨论
数据库·postgresql·开源
赵渝强老师7 小时前
【赵渝强老师】金仓数据库的数据文件
数据库·国产数据库·kingbase·金仓数据库
随逸17711 小时前
《Milvus向量数据库从入门到实战,手把手搭建语义检索系统》
数据库
神秘的猪头11 小时前
🚀 React 开发者进阶:RAG 核心——手把手带你玩转 Milvus 向量数据库
数据库·后端·llm
IvorySQL1 天前
PostgreSQL 技术日报 (3月6日)|为什么 Ctrl-C 在 psql 里让人不安?
数据库·postgresql·开源
NineData1 天前
数据库管理工具NineData,一年进化成为数万+开发者的首选数据库工具?
运维·数据结构·数据库
IvorySQL1 天前
PostgreSQL 技术日报 (3月5日)|规划器控制力升级,内核能力再进阶
数据库·postgresql·开源
数据组小组2 天前
免费数据库管理工具深度横评:NineData 社区版、Bytebase 社区版、Archery,2026 年开发者该选哪个?
数据库·测试·数据库管理工具·数据复制·迁移工具·ninedata社区版·naivicat平替