mysql8.0怎么创建表
时间: 2025-03-28 17:24:25 浏览: 28
### MySQL 8.0 创建表语法及示例
在 MySQL 8.0 中,创建表的核心操作通过 `CREATE TABLE` 语句完成。以下是关于该语句的详细介绍以及一些实际使用的例子。
#### 基础语法
`CREATE TABLE` 的基本结构如下:
```sql
CREATE TABLE table_name (
column1 datatype constraints,
column2 datatype constraints,
...
);
```
其中:
- **table_name**: 表名。
- **columnN**: 列名称。
- **datatype**: 数据类型(如 INT、VARCHAR、DATE 等)。
- **constraints**: 可选约束条件(如 PRIMARY KEY、NOT NULL、UNIQUE 等)[^4]。
#### 实际案例
下面是一些具体的实例来展示如何创建不同类型的表。
##### 示例 1:简单的学生信息表
假设我们需要存储学生的姓名和年龄,则可以这样定义表格:
```sql
CREATE TABLE students (
id INT AUTO_INCREMENT PRIMARY KEY,
name VARCHAR(50) NOT NULL,
age INT CHECK (age >= 0 AND age <= 150),
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
```
此脚本中包含了自增主键 (`AUTO_INCREMENT`)、字符串字段 (`VARCHAR`)、整数字段 (`INT`) 和时间戳默认值设置 (^4])。
##### 示例 2:带有外键关系的学校与学生关联表
如果要建立两个实体之间的联系——比如一所学校的多个学生记录,可以通过 FOREIGN KEY 来实现这种参照完整性控制:
```sql
-- 首先创建 schools 表
CREATE TABLE schools (
school_id INT AUTO_INCREMENT PRIMARY KEY,
school_name VARCHAR(100) UNIQUE NOT NULL
);
-- 接着创建 students 表,并指定 foreign key 关联到 schools 表上
CREATE TABLE students (
student_id INT AUTO_INCREMENT PRIMARY KEY,
first_name VARCHAR(50),
last_name VARCHAR(50),
school_id INT,
CONSTRAINT fk_school FOREIGN KEY(school_id) REFERENCES schools(school_id)
ON DELETE CASCADE -- 当删除某个school时自动清除其对应students数据
);
```
上述SQL片段展示了如何利用FOREIGN KEYS构建多对一的关系模型[^5].
#### 使用窗口函数扩展功能
除了基础的数据管理之外,在较新的版本里还可以结合窗体函数(Window Functions),它们允许我们在查询结果集中执行复杂的计算而无需子查询或者临时表的帮助。例如统计每所学校内的学生数量排名情况就可以采用ROW_NUMBER() OVER(...)形式表达出来[^2]:
```sql
WITH ranked_students AS(
SELECT s.student_id, sc.school_id, COUNT(*) over(PARTITION BY sc.school_id ORDER BY s.age ASC ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW ) rank_num FROM students s JOIN schools sc USING(school_id))
SELECT * FROM ranked_students WHERE rank_num<=3;
```
以上就是有关于MySQL 8.0下创建表的一些基础知识介绍及其应用举例说明.
阅读全文
相关推荐














