CREATE TABLE语句

在创建数据库之后,接下来就要在数据库中创建数据表。所谓创建数据表,指的是在已经创建的数据库中建立新表。

创建数据表的过程是规定数据列的属性的过程,同时也是实施数据完整性(包括实体完整性、引用完整性和域完整性)约束的过程。接下来我们介绍一下创建数据表的语法形式。

基本语法

在 MySQL 中,可以使用 CREATE TABLE 语句创建表。其语法格式为:

CREATE TABLE <表名> (【表定义选项】)【表选项】【分区选项】;
其中,[表定义选项]的格式为:

<列名1> <类型1> [,…] <列名n> <类型n>

CREATE TABLE 命令语法比较多,其主要是由表创建定义(create-definition)、表选项(table-options)和分区选项(partition-options)所组成的。

这里首先描述一个简单的新建表的例子,然后重点介绍 CREATE TABLE 命令中的一些主要的语法知识点。

CREATE TABLE 语句的主要语法及使用说明如下:

【1】CREATE TABLE:用于创建给定名称的表,必须拥有表CREATE的权限。
【2】<表名>:指定要创建表的名称,在 CREATE TABLE 之后给出,必须符合标识符命名规则。表名称被指定为 db_name.tbl_name,以便在特定的数据库中创建表。无论是否有当前数据库,都可以通过这种方式创建。在当前数据库中创建表时,可以省略 db-name。如果使用加引号的识别名,则应对数据库和表名称分别加引号。例如,‘mydb’.‘mytbl’ 是合法的,但 ‘mydb.mytbl’ 不合法。
【3】<表定义选项>:表创建定义,由列名(col_name)、列的定义(column_definition)以及可能的空值说明、完整性约束或表索引组成。
【4】默认的情况是,表被创建到当前的数据库中。若表已存在、没有当前数据库或者数据库不存在,则会出现错误。

提示:使用 CREATE TABLE 创建表时,必须指定以下信息:
【1】要创建的表的名称不区分大小写,不能使用SQL语言中的关键字,如DROP、ALTER、INSERT等。
【2】数据表中每个列(字段)的名称和数据类型,如果创建多个列,要用逗号隔开。

在指定的数据库中创建表

数据表属于数据库,在创建数据表之前,应使用语句“USE<数据库>”指定操作在哪个数据库中进行,如果没有选择数据库,就会抛出 No database selected 的错误。

【实例 1】创建员工表 tb_emp1,结构如下表所示。


选择创建表的数据库 test1,创建 tb_emp1 数据表,输入的 SQL 语句和运行结果如下所示。

语句执行后,便创建了一个名称为 tb_emp1 的数据表,使用 SHOW TABLES;语句查看数据表是否创建成功,如下所示。

查看表结构

在 MySQL 中,使用 SQL 语句创建好数据表之后,可以查看结构的定义,以确认表的定义是否正确。在 MySQL 中,查看表结构可以使用 DESCRIBESHOW CREATE TABLE 语句。

(1)

DESCRIBE/DESC 语句可以查看表的字段信息,包括字段名、字段数据类型、是否为主键、是否有默认值等,语法规则如下:

DESCRIBE <表名>; 或简写成:DESC <表名>;

【实例 2】使用 DESCRIBE 查看表 tb_emp1 的结构,输入的 SQL 语句和运行结果如下所示。

其中,各个字段的含义如下:
【1】Null:表示该列是否可以存储 NULL 值。
【2】Key:表示该列是否已编制索引。PRI 表示该列是表主键的一部分,UNI 表示该列是 UNIQUE 索引的一部分,MUL 表示在列中某个给定值允许出现多次。
【3】Default:表示该列是否有默认值,如果有,值是多少。
【4】Extra:表示可以获取的与给定列有关的附加信息,如AUTO_INCREMENT 等。

(2)

SHOW CREATE TABLE语句可以用来显示创建表时的CREATE TABLE语句,语法格式如下:

SHOW CREATE TABLE <表名>\G;

【实例 3】使用 SHOW CREATE TABLE 查看表 tb_emp1 的详细信息,输入的 SQL 语句和运行结果如下所示。

提示:使用 SHOW CREATE TABLE 语句不仅可以查看创建表时的详细语句,而且可以查看存储引擎和字符编码。如果不加“\G”参数,显示的结果可能非常混乱,加上“\G”参数之后,可使显示的结果更加直观,易于查看。

本文相关参考文献:
[1]明日科技. MySQL从入门到精通[M].北京:清华大学出版社,2007

MySQL学习之路(八):MySQL创建数据表相关推荐

  1. MySQL学习之路 一 : MySQL 5.7.19 源码安装

    MySQL 5.7.19 源码安装 查看系统: # cat /etc/redhat-release CentOS Linux release 7.3.1611 (Core) 安装依赖包 # yum - ...

  2. MySQL学习笔记_4_MySQL创建数据表(下)

    MySQL创建数据表(下) 五.数据表类型及存储位置 1.MySQL与大多数数据库不同,MySQL有一个存储引擎概念.MySQL可以针对不同的存储需求选择不同的存储引擎. 2. showengines ...

  3. MySQL学习笔记_3_MySQL创建数据表(中)

    MySQL创建数据表(中) 三.数据字段属性 1.unsigned[无符号] 可以让空间增加一倍 比如可以让-128-127增加到0-255 注意:只能用在数值型字段 2.zerofill[前导零] ...

  4. MySQL学习笔记_2_MySQL创建数据表(上)

    MySQL创建数据表(上) 一.创建数据表的SQL语句模型[弱类型] CREATETABLE [IF NOT EXISTS] 表名称( 字段名1列的类型[属性][索引], 字段名2 列的类型[属性][ ...

  5. Mysql数据库学习笔记(1.创建数据表)ubuntu18.04

    *创建数据表 用户名:root  密码: 连接数据库:mysql -u root -p 退出数据库:quit; exit; ctrl+D *远程连接 mysql -hip地址 -uroot -p -h ...

  6. xampp mysql创建表_xampp怎样创建数据表和删除数据表 来学习吧

    xampp新建好数据库之后,怎样新建数据表呢?今天咪咪我就来讲解一下xampp中怎样创建数据表和删除数据表. 工具/材料 电脑 电脑 xampp 操作方法 01 如图,单击选中已经创建好的数据库. 0 ...

  7. MySQL 创建数据表

    MySQL 创建数据表 创建MySQL数据表的SQL语法: CREATE TABLE table_name (column_name column_type); 例如,我们在 PENGKE 数据库中创 ...

  8. MySQL创建数据表(CREATE TABLE语句)

    在创建数据库之后,接下来就要在数据库中创建数据表.所谓创建数据表,指的是在已经创建的数据库中建立新表. 创建数据表的过程是规定数据列的属性的过程,同时也是实施数据完整性(包括实体完整性.引用完整性和域 ...

  9. phpstudy mysql创建表_MySQL_Mysql入门基础 数据库创建篇,1.创建数据表---基础(高手跳 - phpStudy...

    Mysql入门基础 数据库创建篇 1.创建数据表---基础(高手跳过) 正统方法:create [TEMPORARY] table 表名 [if not exists] (创建的列项定义) [表的选项 ...

最新文章

  1. CTFshow 文件上传 web157
  2. 19、SQL Server 数据修改之Insert into
  3. .net随笔-vb.net 系统计时器
  4. ssdp协议 upnp_SSDP 简单服务发现协议
  5. 服务动态选择域名问题
  6. 编程三角形面积公式_利用边长计算三角形面积 — 海伦公式推导
  7. 荣耀30S首发新一代神U麒麟820 5G:GeekBench得分媲美骁龙855
  8. pair用法 lower_bound upper_bound
  9. pypy mysql 兼容_PyPy运行Django+MySQL简单教程
  10. 关于macos新功能——控制中心的一些事
  11. Java8下载安装详细教程,环境配置,Java、jre下载安装教程,此电脑图标位置,电脑处理器版本查询查询
  12. 《Java开发实战经典》习题第3章第12题:使用for循环打印下面的图形(用for循环打印金字塔)
  13. 数学表达式基础——2 集合、向量与矩阵
  14. 【毕业设计源码】基于JAVA的自驾游小程序的设计与实现
  15. LeetCode-Hot100-最长回文子串
  16. java.util 语言_java中的import java.util是什么意思
  17. 计算机学硕报考院校人数,2020考研报考人数:这些学校人数过万!
  18. 虚拟机共享WiFi网路的NAT连接方法
  19. explain的使用及详解
  20. className和classList区别

热门文章

  1. 【原创】数据分析的荣耀与骄傲
  2. 百度地图:2022年度中国城市交通报告
  3. 马云寄语清华经管毕业生:做未来最重要的事情
  4. js 把一个对象赋值给另一个对象
  5. ColorSnapper2 for Mac(专业屏幕取色软件)
  6. win10访问文件共享服务器目录,显示无访问权限时,关于不提示用户名和密码输入的解决办法
  7. JS字符串补全方法padStart()和padEnd()简介
  8. 设置 MAYA 2013 界面 语言
  9. 如何快速升级 Cocos Shader 版本,以简易水shader为例
  10. 导出Echarts图表