1 Create database语句

create database 语句是在MySQL实例上创建一个指定名的数据库, create schema语句的语义和 create database是一样的。先来看下create的语法:

Syntax:
CREATE {DATABASE | SCHEMA} [IF NOT EXISTS] db_name
[create_specification] ... create_specification:
[DEFAULT] CHARACTER SET [=] charset_name
| [DEFAULT] COLLATE [=] collation_name
  • 当创建的数据库本身存在而且没有写明 if not exists子句时,则创建数据库的语句会报错,实例如下:
  • create_specification子句指明创建的数据库的属性,并存储在 db.opt文件中’
    • character set属性指明此数据库的默认字符集
    • collate属性指明此数据库的默认排序规则
  • 创建后的数据库在数据文件所在的目录会创建一个与数据库名相同的文件目录,用来包含后续创建的表文件;
  • 当然,也可以直接通过 mkdir的操作系统命令在数据目录创建文件夹,则MySQL会识别为一个数据库,并在执行 show databases命令时可以看到。

创建数据示例如下:

  • 通过在data目录下创建目录来创建数据库:

    注意:8.0版本中不支持通过这种 方式创建数据库。

  • 使用create database创建数据库:

mysql> create database test;	##创建数据库成功
Query OK, 1 row affected (0.08 sec) mysql> create database test; ##再次创建数据库失败
ERROR 1007 (HY000): Can't create database 'test'; database exists
mysql> create database if not exists test; ##语句执行成功
Query OK, 1 row affected, 1 warning (0.01 sec) mysql> use test; ##切换到test数据库
Database changed

2 Create table语句

create table语句是在数据库中创建表。在MySQL实例中可以 通过 ? create table方式来查看其语法:

Syntax:
CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name
(create_definition,...)
[table_options]
[partition_options] CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name
[(create_definition,...)]
[table_options]
[partition_options]
[IGNORE | REPLACE]
[AS] query_expression CREATE [TEMPORARY] TABLE [IF NOT EXISTS] tbl_name
{ LIKE old_tbl_name | (LIKE old_tbl_name) }

2.1 创建表的三种方式详解

  • table_name表示被创建的表名,默认在当前数据库下创建此表,当然也可以指定在某个数据库下创建表;
  • if not exists表示当相同的表名存在是,则不执行此创建语句,避免语句执行错误
mysql> use test;
Database changed
mysql> create table student(sid int,sname varchar(10));
Query OK, 0 rows affected (0.11 sec) mysql> create table test1.student(sid int,sname varchar(10)); ##在test1数据库下创建student表
Query OK, 0 rows affected (0.15 sec)
mysql> create table if not exists student(sid int,sname varchar(10));
  • temporary关键词表示创建的是临时表,临时表仅对本次登陆MySQL实例的用户可见,另外的数据库连接不可见。当本连接断开时,临时表也会被 drop掉。
mysql> create temporary table temp1(sid int,sname varchar(10));
Query OK, 0 rows affected (0.00 sec) mysql> insert into temp1 values(1,'a');
Query OK, 1 row affected (0.01 sec) ##另一个数据库连接执行相同的查询语句查不到数据
mysql> select * from temp1;
ERROR 1146 (42S02): Table 'test.temp1' doesn't exist
##本数据库连接断开后再连接,临时表也不存在
mysql> select * from temp1;
ERROR 1046 (3D000): No database selected
  • like关键词表示基于另外一个表的定义赋值一个新的空表。空表上的字段属性和索引都和原表相同
mysql> create table students_copy like student;
Query OK, 0 rows affected (0.04 sec) ##验证like关键在创建表时只复制原表的字段信息,不复制表中的内容 ##删除students_copy表
mysql> drop table students_copy;
Query OK, 0 rows affected (0.13 sec) ##修改stedent表名为students
mysql> alter table student rename to students;
Query OK, 0 rows affected (0.06 sec) ##给students表添加一个gender int字段
mysql> alter table students add(gender int);
Query OK, 0 rows affected (0.05 sec)
Records: 0 Duplicates: 0 Warnings: 0 ##修改students表的字段属性,sname不能为空,sid为主键
mysql> alter table students modify sname varchar(20) not null;
Query OK, 0 rows affected (0.01 sec)
Records: 0 Duplicates: 0 Warnings: 0 mysql> alter table students add primary key(sid);
Query OK, 0 rows affected (0.04 sec)
Records: 0 Duplicates: 0 Warnings: 0 ##给students表中的sname字段创建一个索引
mysql> create index idx_1 on students(sname);
Query OK, 0 rows affected (0.11 sec)
Records: 0 Duplicates: 0 Warnings: 0 ##使用like关键创建一个students_copy表
mysql> create table students_copy like students;
Query OK, 0 rows affected (0.03 sec)
  • create table ... as select语句表示创建表的同时将select的查询结果数据插入到表中,但索引和主外键信息都不会同步过来
##复制所有字段上的数据
mysql> create table students_copy2 as select * from students where sid=1;
Query OK, 1 row affected (0.09 sec)
Records: 1 Duplicates: 0 Warnings: 0 ##选择指定字段上的数据进行复制
mysql> create table students_copy3 as select sid,sname from students where sid = 1;
Query OK, 1 row affected (0.10 sec)
Records: 1 Duplicates: 0 Warnings: 0 ##使用desc语句查看表的字段信息
mysql> desc students_copy3;
+-------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| sid | int(11) | NO | | NULL | |
| sname | varchar(20) | NO | | NULL | |
+-------+-------------+------+-----+---------+-------+
2 rows in set (0.00 sec)

2.2 create table的其他选项

  • ignore replace表示在插入数据的过程中如果新表中碰到违反唯一约束的情况下怎么处理, ignore表示不插入, replace表示替换已有的数据,默认两个关键词都不写则碰到违反的情况会报错
  • data_type表示定义的字段类型
  • not null/null表示字段是否允许为空,默认为 null表示允许为空, not null表示需要对此字段明确数值,或者要有默认值,否则报错
mysql> create table student2(sid int not null,sname varchar(20));
Query OK, 0 rows affected (0.08 sec) mysql> insert into student2(sname) values('dabric');
ERROR 1364 (HY000): Field 'sid' doesn't have a default value
  • default表示设置字段的默认值
mysql> create table student3(sid int not null,sname varchar(10),gender int default 0);
Query OK, 0 rows affected (0.05 sec) mysql> insert into student3 values(1,'tom',default);
Query OK, 1 row affected (0.08 sec) mysql> insert into student3(sid,sname) values(1,'jerry');
Query OK, 1 row affected (0.10 sec)
  • auto_increment表示字段为整数或者浮点数类型的 value+1递增数值, value为当前表中该字段最大的值,默认是从1开始递增;一个表中只容许有一个自增字段,且该字段必须有 key属性,不能含有 default属性,如果是负值会被当成很大的正数

  • column_format目前仅在 ndb存储引擎的表上有用,表示该字段的存储类型是 fixed dynamic或者 default

  • storage 目前也仅在ndb存储引擎的表上有用

  • constraint表示为主键、唯一键、外键等约束条件命名,如果没有命名则MySQL会默认给一个

  • primary_key表示该字段为主键,主键字段必须唯一,必须非空,一个表中只能有一个主键,主键可以包含一个或多个字段

  • key/index表示索引字段

  • unique表示该字段为唯一属性字段,且允许包含多个null

##创建sid字段索引的unique
mysql> create unique index idx_2 on students(sid);
Query OK, 0 rows affected (0.05 sec)
Records: 0 Duplicates: 0 Warnings: 0 mysql> create unique index idx_3 on students(sname);
Query OK, 0 rows affected (0.11 sec)
Records: 0 Duplicates: 0 Warnings: 0 ##多个字段的unique,必须保证两个字段叠加在一起不重复
mysql> create unique index idx_4 on students(sid,sname);
Query OK, 0 rows affected (0.09 sec)
Records: 0 Duplicates: 0 Warnings: 0
  • foreign key表示该字段为外键字段

    • 如果某个字段是另一个表中的字段的外键,在删除这条数据时,得先删除和外键相关的那条数据
mysql> create table 'gender'(
gender_id int(11) not null,
name varchar(10) default null,
primary key (gender_id)
)
mysql> create student5(sid int not nll primary key auti_increment,sname varchar(10) unique,gender int,constraint for_1 foreign key(gender) references gender(gender_id))

3 案例练习

设计一个学生选课数据库系统

  • 创建一个名为course的数据库

  • 在该数据库下创建一下几个表:

    • student表:sid整型自增主键,sname字符串64位,gender字符串12位,dept_id整型并外键到dept表的id字段

    • dept表:id整型自增主键,dept_name字符串64位

    • course表:id整型自增字段主键,course_name字符串64位,teacher_id整型外键到teacher表的id字段

    • teacher表:id整型自增字段主键,name字符创64位,dept_id整型外键到dept表的id字段

  • students表和teacher表的dept_id为非空

mysql> create table dept(id int primary key auto_increment,dept_name varchar(64));

mysql> create table student(sid int primary key auto_increment,sname varchar(64),gender varchar(12),dept_id int,constraint for_1 foreign key(dept_id) references dept(id));

mysql> alter table student modify dept_id int not null;

mysql> create table teacher(id int primary key auto_increment,name varchar(64),dept_id int not null,constraint for_2 foreign key(dept_id) references dept(id))

mysql> create table course(id int primary key auto_increment,course_name varchar(64),teacher_id int,constraint for_3 foreign key(teacher_id) references teacher(id));

SQL基础语法—create语句的更多相关文章

  1. SQL基础语法—insert语句

    1 insert语句 insert语句用于插入数据到表中,其基本语法有以下三种: Syntax: INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IG ...

  2. SQL基础语法—update语句

    1 update语句介绍 update语句用来修改表中的数据内容 Single-table syntax: UPDATE [LOW_PRIORITY] [IGNORE] table_reference ...

  3. SQL语法基础之CREATE语句

    SQL语法基础之CREATE语句 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.查看帮助信息 1>.使用“?”来查看MySQL命令的帮助信息 mysql> ? CR ...

  4. ASP.NET实现二维码 ASP.Net上传文件 SQL基础语法 C# 动态创建数据库三(MySQL) Net Core 实现谷歌翻译ApI 免费版 C#发布和调试WebService ajax调用WebService实现数据库操作 C# 实体类转json数据过滤掉字段为null的字段

    ASP.NET实现二维码 using System;using System.Collections.Generic;using System.Drawing;using System.Linq;us ...

  5. SQL基础语法笔记教程整理

    PS:本文适用SQL Server2008语法. 一.关系型数据库和SQL 实际上准确的讲,SQL是一门语言,而不是一个数据库. 什么是SQL呢?简而言之,SQL就是维护和使用关系型数据库中的的数据的 ...

  6. SQL 基础语法笔记教程整理

    最近从图书馆借了本介绍 SQL 的书,打算复习一下基本语法,记录一下笔记,整理一下思路,以备日后复习之用. PS:本文适用 SQL Server2008 语法. 首先,附一个发现的 MySQL 读书笔 ...

  7. Spring mybatis源码篇章-动态SQL基础语法以及原理

    通过阅读源码对实现机制进行了解有利于陶冶情操,承接前文Spring mybatis源码篇章-Mybatis的XML文件加载 前话 前文通过Spring中配置mapperLocations属性来进行对m ...

  8. SQL基础语法(二)

    SQL SELECT 语句 本章讲解 SELECT 和 SELECT * 语句. SQL SELECT 语句 SELECT 语句用于从表中选取数据. 结果被存储在一个结果表中(称为结果集). SQL ...

  9. SQL基础语法提纲

    一.SQL需知5点 1.SQL是Structured Query Language的缩写,是用来访问关系型数据库的,非过程化的,高级编程语言. 2.SQL具有语法高度综合统一,高度的非过程化,对集合进 ...

随机推荐

  1. 题解 AT3853 【Otoshidama】

    题目传送门. 暴力枚举题. 分析 Step 1:定义两个变量,\(n\)和\(y\). int n,y; cin>>n>>y; Step 2:使用二重循环进行暴力枚举. for ...

  2. SpringBoot学习- 10、设计用户角色权限表

    SpringBoot学习足迹 前几节已经基本了解了SpringBoot框架常用的技术,其他的消息队列,定时器等技术暂时用不到,真正项目中如果基于微信系,阿里系开发的话,还要了解平台专用的技术知识,学习 ...

  3. 执行python程序的方式

    1.交互器 程序不能永久保存 主要用于简单的语法测试相关 2.文件执行

  4. C语言sprintf函数的深入理解

    由于sprintf跟printf在用法上几乎一样,只是打印的目的地不同而已,前者打印到字符串中,后者则直接在命令行上输出.这也导致sprintf比printf有用得多.所以本文着重介绍sprintf, ...

  5. POJ 1330(LCA/倍增法模板)

    链接:http://poj.org/problem?id=1330 题意:q次询问求两个点u,v的LCA 思路:LCA模板题,首先找一下树的根,然后dfs预处理求LCA(u,v) AC代码: #inc ...

  6. 并查集-G - 食物链

    G - 食物链 动物王国中有三类动物A,B,C,这三类动物的食物链构成了有趣的环形.A吃B, B吃C,C吃A.现有N个动物,以1-N编号.每个动物都是A,B,C中的一种,但是我们并不知道它到底是哪一种 ...

  7. 管理QT的组件

    1.在qt的安装目录找到'%QTROOT%\MaintenanceTool.exe'. 2.点击MaintenanceTool的设置,可以设置默认储存库.临时储存库.用户定义储存库,选择其中的临时储存 ...

  8. [ASP.NET]Web网站与Web应用程序区别

    [ASP.NET]Web网站与Web应用程序区别   本文链接:https://blog.csdn.net/a954553391/article/details/86403521 前言:在项目开发中, ...

  9. AcWing 827. 双链表

    https://www.acwing.com/problem/content/829/ #include <iostream> using namespace std; ; int m; ...

  10. Apache Kafka(九)- Kafka Consumer 消费行为

    1. Poll Messages 在Kafka Consumer 中消费messages时,使用的是poll模型,也就是主动去Kafka端取数据.其他消息管道也有的是push模型,也就是服务端向con ...