当前位置: 首页 > article >正文

【重学 MySQL】四十六、创建表的方式

【重学 MySQL】四十六、创建表的方式

  • 使用CREATE TABLE语句创建表
  • 使用CREATE TABLE LIKE语句创建表
  • 使用CREATE TABLE AS SELECT语句创建表
  • 使用CREATE TABLE SELECT语句创建表并从另一个表中选取数据(与CREATE TABLE AS SELECT类似)
  • 使用CREATE TEMPORARY TABLE语句创建临时表
  • 指定表空间的创建方式
  • 注意事项

在这里插入图片描述

使用CREATE TABLE语句创建表

这是MySQL中创建表最常用的方式,可以通过手动定义表的结构来完成表的创建。CREATE TABLE语句的基本语法如下:

CREATE TABLE [IF NOT EXISTS] table_name (
    column1 datatype constraints,
    column2 datatype constraints,
    ...
    [table_constraints]
);
  • table_name:指定要创建的表的名称。
  • column1, column2, ...:定义表中的列,包括列名和数据类型,以及可选的约束条件。
  • datatype:指定列的数据类型,如INT、VARCHAR、DATE等。
  • constraints:对列进行约束,如NOT NULL、PRIMARY KEY、UNIQUE等。
  • table_constraints:可选的表级约束,如FOREIGN KEY等。

例如,创建一个名为department的表,包含部门编号和部门名称两个字段:

CREATE TABLE department (
    dept_id INT NOT NULL PRIMARY KEY,
    dept_name VARCHAR(50) NOT NULL
);

使用CREATE TABLE LIKE语句创建表

这种方式可以复制已有表的结构来创建新表,但不会复制数据。语法如下:

CREATE TABLE [IF NOT EXISTS] new_table_name LIKE existing_table_name;

例如,基于employee表的结构创建一个名为emp_copy的新表:

CREATE TABLE emp_copy LIKE employee;

使用CREATE TABLE AS SELECT语句创建表

这种方式可以通过从另一个表中选取数据来创建新表,并同时复制数据。语法如下:

CREATE TABLE new_table_name AS
SELECT column1, column2, ...
FROM existing_table_name
[WHERE condition];

例如,从employee表中选取所有员工的信息创建一个名为emp_backup的新表:

CREATE TABLE emp_backup AS
SELECT * FROM employee;

使用CREATE TABLE SELECT语句创建表并从另一个表中选取数据(与CREATE TABLE AS SELECT类似)

这种方式与CREATE TABLE AS SELECT类似,也是通过从另一个表中选取数据来创建新表,但具体语法可能因MySQL版本而异。在某些版本中,可能需要使用CREATE TABLE new_table_name SELECT ...的形式。

使用CREATE TEMPORARY TABLE语句创建临时表

临时表只在当前会话中有效,当会话结束时,临时表会自动删除。语法如下:

CREATE TEMPORARY TABLE table_name (
    column1 datatype constraints,
    column2 datatype constraints,
    ...
);

例如,创建一个名为temp_table的临时表:

CREATE TEMPORARY TABLE temp_table (
    id INT PRIMARY KEY,
    name VARCHAR(50) NOT NULL
);

指定表空间的创建方式

在创建表时,还可以指定表空间来存储表的数据。这需要使用TABLESPACE关键字。语法如下:

CREATE TABLE table_name (
    column1 datatype constraints,
    column2 datatype constraints,
    ...
) TABLESPACE tablespace_name;

其中,tablespace_name是预先创建好的表空间的名称。

注意事项

  1. 在创建表之前,应确保已经连接到MySQL数据库,并具有相应的权限。
  2. 表名、列名等标识符应使用有效的MySQL标识符命名规则。
  3. 数据类型和约束条件应根据实际需求进行选择和设置。
  4. 创建表时,可以使用ENGINE关键字指定表的存储引擎,如InnoDB、MyISAM等。

通过以上方式,可以在MySQL中灵活地创建表,以满足不同的数据存储需求。


http://www.kler.cn/a/329925.html

相关文章:

  • SurfaceFlinger代码笔记
  • C#上位机通过CAN总线发送bin文件
  • openharmony标准系统方案之瑞芯微RK3568移植案例
  • macos arm 本地/docker/本地k8s 安装jupyterhub 并登陆
  • 【网络云SRE运维开发】2025第3周-每日【2025/01/15】小测-【第14章ospf高级配置】理论和实操解析
  • 基于 STM32 的多功能时间管理器项目
  • 2024 全新体验:国学心理 API 接口来袭
  • ES索引生命周期管理
  • 一次oracle迁移11g到19c后用到的对象数量对比脚本
  • Golang 服务器虚拟化应用案例
  • Django学习笔记四:urls配置详解
  • Geoserver关于忘记密码的解决方法
  • 无头双向不循环链表的模拟
  • 千兆网络变压器HX84801SP POE应用主板
  • 秋招|面试|群面|求职
  • 服务架构的演进之路:从单体应用到Serverless
  • 【初阶数据结构】排序——归并排序
  • Stable Diffusion绘画 | 来训练属于自己的模型:打标处理与优化
  • 接口测试入门:深入理解接口测试!【电商API接口测试】
  • 【Qt】系统相关学习--底层逻辑--代码实践
  • 【Redis】主从复制(上)
  • linux文件编程_进程通信
  • 《中安未来护照阅读器 —— 机场高效通行的智慧之选》
  • 一、前后端分离及drf的概念
  • 15 种高级 RAG 技术 从预检索到生成
  • Linux开发讲课45--- 链表