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;
相关推荐
麦聪聊数据1 小时前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_1 小时前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡2 小时前
【MySQL数据库】数据类型与表约束
数据库·mysql
曹牧2 小时前
Oracle EXPLAIN PLAN
数据库·oracle
BD_Marathon2 小时前
SQL学习指南——视图
数据库·sql
活宝小娜2 小时前
mysql详细安装教程
数据库·mysql·adb
贤时间2 小时前
codex 助力oracle ebs 开发
数据库·oracle
秉承初心3 小时前
PostgreSQL 数据性能瓶颈突破实战
数据库·postgresql·oracle
2601_962072553 小时前
李梦娇常识4600问|题库|打印版
sql·华为od·华为·c#·华为云·.net·harmonyos