来源:阿里云天池龙珠计划SQL训练营https://tianchi.aliyun.com/specials/promotion/aicampsql;
1 数据库概述
1.1 DBMS常见概念及种类
两个概念:数据库(Database,DB),数据库管理系统(Database Management System,DBMS)。
现有数据库可以分为:层次数据库、关系数据库、面向对象数据库、XML数据库、键值存储数据库等5中类型,其中关系数据库尤为常见。管理关系数据库的DBMS称为关系数据库管理系统,常见的有甲骨文的Oracle、微软的SQL Server、IBM的DB2、开源的MySQL。
1.2 关系数据库管理系统结构
常见RDBMS系统结构为客户端/服务器类型(C/S类型),如图1-3。
1.3 数据库安装
1.3.1 阿里云MySQL服务器
http://tianchi-media.oss-cn-beijing.aliyuncs.com/dragonball/SQL/other/阿里云MySQL服务器使用介绍.pdf
1.3.2 MySQL搭建
http://tianchi-media.oss-cn-beijing.aliyuncs.com/dragonball/SQL/other/本地MySQL环境搭建方法介绍.pdf
1.3.3 MySQL服务器集成
因为还没有找到合适的Window+MySQL+Python的集成环境,并且在搭建MySQL时经常因为系统问题需要配置很多环境,所以目前使用的是Wampserver。
2 理解关系数据库
2.1 表的存储结构
将关系数据库类比成Excel表格,就很容易理解关系数据库中存储的表结构,如图1-6。
2.2 常用数据类型
- INT 型
用来存储整数的列的数据类型(数字型),不能存储小数。
- CHAR 型
用来存储定长字符串,当列中存储的字符串长度达不到最大长度的时候,使用半角空格进行补足,由于会浪费存储空间,所以一般不使用。
- VARCHAR 型
用来存储可变长度字符串,定长字符串在字符数未达到最大长度时会用半角空格补足,但可变长字符串不同,即使字符数未达到最大长度,也不会用半角空格补足。
- DATE 型
用来指定存储日期(年月日)的列的数据类型(日期型)。
3 SQL语言
3.1 SQL 语句种类.
- DDL
DDL(Data Definition Language,数据定义语言) 用来创建或者删除存储数据用的数据库以及数据库中的表等对象。DDL 包含以下几种指令。
-
CREATE : 创建数据库和表等对象
-
DROP : 删除数据库和表等对象
-
ALTER : 修改数据库和表等对象的结构
- DML
DML(Data Manipulation Language,数据操纵语言) 用来查询或者变更表中的记录。DML 包含以下几种指令。
-
SELECT :查询表中的数据
-
INSERT :向表中插入新数据
-
UPDATE :更新表中的数据
-
DELETE :删除表中的数据
- DCL
DCL(Data Control Language,数据控制语言) 用来确认或者取消对数据库中的数据进行的变更。除此之外,还可以对 RDBMS 的用户是否有权限操作数据库中的对象(数据库表等)进行设定。DCL 包含以下几种指令。
-
COMMIT : 确认对数据库中的数据进行的变更
-
ROLLBACK : 取消对数据库中的数据进行的变更
-
GRANT : 赋予用户操作权限
-
REVOKE : 取消用户的操作权限
3.2 SQL书写规范
- SQL语句要以分号( ; )结尾
- SQL 不区分关键字的大小写,但是插入到表中的数据是区分大小写的
- win 系统默认不区分表名及字段名的大小写
- linux / mac 默认严格区分表名及字段名的大小写
- 本教程已统一调整表名及字段名的为小写,以方便初学者学习使用。
- 常数的书写方式是固定的,'abc', 1234, '26 Jan 2010', '10/01/26', '2010-01-26'…
- 单词需要用半角空格或者换行来分隔
SQL 语句的单词之间需使用半角空格或换行符来进行分隔,且不能使用全角空格作为单词的分隔符,否则会发生错误,出现无法预期的结果。
3.3 SQL语法
--DDL(数据定义语言)
--CREATE
--数据库的创建
CREATE DATABASE < 数据库名称 > ;
--表的创建
CREATE TABLE < 表名 >(
< 列名 1> < 数据类型 > < 该列所需约束 > ,
< 列名 2> < 数据类型 > < 该列所需约束 > ,
< 列名 3> < 数据类型 > < 该列所需约束 > ,
< 列名 4> < 数据类型 > < 该列所需约束 > ,
.
.
.
< 该表的约束 1> ,
< 该表的约束 2> ,……
);
/*常用列约束有非空约束NOT NULL、默认值约束DEFAULT 0、表约束常用主键约束PRIMARY KEY (列名)*/
--删除表
DROP TABLE < 表名 > ;
--ALTER
--添加列
ALTER TABLE < 表名 > ADD COLUMN < 列名 > < 数据类型 >;
--删除列
ALTER TABLE < 表名 > DROP COLUMN < 列名 >;
--清空表内容
TRUNCATE TABLE < 表名 >; /*效率较高*/
--DML(数据操纵语言)
--UPDATE
--表内容更新
UPDATE <表名>
SET <列名> = <表达式>
[, <列名2>=<表达式2>...]
WHERE <条件> -- 可选,非常重要,注意添加 where 条件,否则将会将所有的行按照语句修改。
ORDER BY 子句 --可选
LIMIT 子句; --可选
/*使用 UPDATE 也可以将列更新为 NULL(该更新俗称为NULL清空)。此时只需要将赋值表达式右边的值直接写为 NULL 即可。但是,只有未设置 NOT NULL 约束和主键约束的列才可以清空为NULL。**如果将设置了上述约束的列更新为 NULL,就会出错*/
--INSERT
--表内容插入
INSERT INTO <表名> (列1, 列2, 列3, ……)
VALUES (值1.1, 值2.1, 值3.1, ……)
[,(值1.2, 值2.2, 值3.2, ……)];
--从其他表复制数据
INSERT INTO <表名1> (列1, 列2, 列3, ……)
SELECT 列1, 列2, 列3, ……
FROM <表名2>;