创建表的基础语法
CREATE TABLE 表名 ( 列名1 数据类型 [约束条件], 列名2 数据类型 [约束条件], ... [表级约束] );
- 关键组成部分:
- 表名:字母、数字或下划线组成(建议全小写),如
user_info
。 - 列名:每列的唯一标识,如
id
,name
。 - 数据类型:定义列存储的数据类型(见下表)。
- 约束条件:保证数据完整性的规则(如主键、非空等)。
- 表名:字母、数字或下划线组成(建议全小写),如
常用数据类型
类型 | 说明 | 示例 |
---|---|---|
INT |
整型 | age INT |
VARCHAR(n) |
可变长度字符串 | name VARCHAR(50) |
DATE |
日期(YYYY-MM-DD) | birthday DATE |
DECIMAL(m,n) |
精确小数(m总位数,n小数位) | price DECIMAL(10,2) |
BOOLEAN |
布尔值(true/false) | is_active BOOLEAN |
约束条件的详细应用
约束是保证数据准确性的核心,分为列级约束(单列)和表级约束(多列):
-
主键约束(PRIMARY KEY)
唯一标识每行,且不允许为空:CREATE TABLE employees ( id INT PRIMARY KEY, -- 列级约束 name VARCHAR(50) ); -- 或表级约束(多列主键) CREATE TABLE orders ( order_id INT, product_id INT, PRIMARY KEY (order_id, product_id) -- 联合主键 );
-
外键约束(FOREIGN KEY)
关联其他表的主键,维护引用完整性:CREATE TABLE orders ( order_id INT PRIMARY KEY, user_id INT, FOREIGN KEY (user_id) REFERENCES users(id) -- 关联users表的id列 );
-
非空约束(NOT NULL)
强制列不允许为空值:CREATE TABLE users ( email VARCHAR(100) NOT NULL -- 邮箱必填 );
-
唯一约束(UNIQUE)
确保列值不重复(允许空值):CREATE TABLE products ( product_code VARCHAR(20) UNIQUE -- 商品编码不可重复 );
-
默认值(DEFAULT)
指定列的默认数据:CREATE TABLE logs ( created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP -- 自动填充当前时间 );
完整创建表示例
创建一个用户信息表,包含:
- 用户ID(主键)
- 姓名(非空)
- 邮箱(唯一且非空)
- 注册时间(默认当前时间)
- 余额(精确小数)
CREATE TABLE users ( user_id INT AUTO_INCREMENT PRIMARY KEY, -- 自增主键 username VARCHAR(30) NOT NULL, email VARCHAR(100) NOT NULL UNIQUE, reg_date TIMESTAMP DEFAULT CURRENT_TIMESTAMP, balance DECIMAL(10,2) DEFAULT 0.00, CHECK (balance >= 0) -- 确保余额非负 );
高级技巧与注意事项
-
自增字段(AUTO_INCREMENT)
适用于主键自动生成(MySQL),PostgreSQL使用SERIAL
,SQL Server用IDENTITY
。 -
检查约束(CHECK)
自定义条件验证数据(如确保年龄>0):CREATE TABLE students ( age INT CHECK (age > 0) );
-
表注释与列注释
增强可读性(MySQL示例):CREATE TABLE employees ( id INT COMMENT '员工唯一ID', name VARCHAR(50) COMMENT '员工姓名' ) COMMENT='公司员工信息表';
-
避免的常见错误:
- 语法错误:遗漏逗号、括号不匹配。
- 命名冲突:使用保留字(如
order
,group
)需用反引号包裹:`order`
。 - 性能问题:过长的
VARCHAR
或不合理的主键设计影响查询效率。
不同数据库的语法差异
操作 | MySQL | PostgreSQL | SQL Server |
---|---|---|---|
自增主键 | AUTO_INCREMENT |
SERIAL |
IDENTITY(1,1) |
字符串类型 | VARCHAR |
VARCHAR/TEXT |
NVARCHAR |
注释 | COMMENT |
单独 COMMENT 命令 |
扩展属性存储 |
创建表是构建数据库的基础,重点在于:
- 明确定义列的数据类型(避免存储空间浪费)。
- 合理使用约束(主键、外键、非空等)保障数据质量。
- 为表和列添加注释提升可维护性。
实际开发中,推荐使用可视化工具(如DBeaver、Navicat)辅助生成SQL语句,降低出错概率,首次部署前需在测试环境验证脚本,避免生产事故。
引用说明参考关系数据库标准SQL:2016规范、MySQL 8.0官方文档及Microsoft SQL Server技术手册,结合实际开发经验编写,数据类型与约束的兼容性说明基于多数据库系统测试验证。
原创文章,发布者:酷盾叔,转转请注明出处:https://www.kd.cn/ask/33401.html