MySQL创建数据库与表:详解CREATE DATABASE与CREATE TABLE语句

0 下载量 138 浏览量 更新于2024-08-03 收藏 2KB TXT 举报
本资源提供了一段关于MySQL创建数据库和表的示例代码,并详细解释了其中的关键选项和约束。 在MySQL中,创建数据库是构建数据存储结构的第一步。`CREATE DATABASE`语句用于创建新的数据库。在示例中,`IF NOT EXISTS`是一个条件,确保如果数据库`mydatabase`已经存在,系统将不会尝试再次创建,从而避免错误。`CHARACTER SET utf8mb4`和`COLLATE utf8mb4_unicode_ci`分别定义了数据库的字符集和校对规则,utf8mb4支持包含表情在内的四字节Unicode字符,而utf8mb4_unicode_ci则规定了字符的比较和排序方式,保证了多语言字符的正确处理。 创建完数据库后,我们需要选择一个数据库进行操作,这通过`USE`语句实现。在本例中,`USE mydatabase;`使当前会话与`mydatabase`数据库关联,后续的所有SQL命令都将在这个数据库内执行。 接下来,我们创建一个名为`users`的表,这使用了`CREATE TABLE`语句。`IF NOT EXISTS`同样用于防止重复创建表。表结构包括四个字段:`id`、`name`、`email`和`created_at`。 - `id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY`定义了`id`字段,这是一个无符号整数,不允许负值。`AUTO_INCREMENT`意味着每次新插入记录时,该字段会自动增加一个唯一的数值,`PRIMARY KEY`指定`id`为表的主键,确保每条记录的唯一性。 - `name VARCHAR(50) NOT NULL`定义了`name`字段,它是一个最多可存储50个字符的可变长度字符串,`NOT NULL`约束表示该字段不能有空值。 - `email VARCHAR(50) NOT NULL UNIQUE`类似地定义了`email`字段,也是最多50个字符的字符串,但添加了`UNIQUE`约束,确保每个邮箱地址在表中都是唯一的,同样不允许为空。 - `created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP`定义了`created_at`字段,这是一个时间戳类型,其默认值为当前时间,这使得在插入新记录时,该字段会自动记录插入的时间。 这段代码提供了创建一个基础用户信息表的模板,包括用户的ID、姓名、电子邮件和创建时间,同时考虑到了数据完整性和唯一性的要求。这样的设计对于许多Web应用程序来说非常常见,可以有效地存储和管理用户数据。