本章目录
参考:https://github.com/datawhalechina/wonderful-sql
数据库:DB
数据库管理系统:DBMS
1 RDBMS
- 行:记录;列:字段
- 完全基于标准 SQL 的 RDBMS 很少,通常需要根据不同的 RDBMS 来编写特定的 SQL 语句,原则上,本课程介绍的是标准 SQL 的书写方式
1.1 SQL语言分类
1.2 SQL的基本书写规则
- 并列的、一个括号里的要逗号
2 DDL
- create
- drop
- alter
- DML:select、insert、update、delete、DCL
2.1 数据库、表、列的命名规则
- 只能使用半角英文字母、数字、下划线_
- 名称必须以半角英文字母开头
2.2 部分数据类型
2.3 部分约束
- default 0:默认列设置为0值
2.4 数据库:创建
create database <数据库名>
2.5 表:创建、删除、更新
2.5.1 创建表、删除表:create、drop
- 创建表
CREATE TABLE < 表名 >
( < 列名 1> < 数据类型 > < 该列所需约束 > ,
< 列名 2> < 数据类型 > < 该列所需约束 > ,
< 列名 3> < 数据类型 > < 该列所需约束 > ,
< 列名 4> < 数据类型 > < 该列所需约束 > ,
.
.
.
< 该表的约束 1> , < 该表的约束 2> ,……);
- 删除表
DROP TABLE < 表名 > ;
2.5.2 向表中插入数据:insert
-- 包含列清单
INSERT INTO <表名> (列1, 列2, 列3, ……) VALUES (值1, 值2, 值3, ……);
INSERT INTO <表名> (列1, 列2, 列3, ……) VALUES (值1, 值2, 值3, ……);
-- 省略列清单
INSERT INTO <表名> VALUES (值1, 值2, 值3, ……);
-- 多列添加
INSERT INTO <表名> VALUES (值1, 值2, 值3, ……),
(值1, 值2, 值3, ……);
-- 值可填null
- 单列添加
- 多列添加
2.5.3 从其他表复制数据
INSERT INTO productcopy (product_id, product_name, product_type, sale_price, purchase_price, regist_date)
SELECT product_id, product_name, product_type, sale_price, purchase_price, regist_date
FROM Product;
2.5.4 添加列、删除列:alter+add/drop
- 添加列
ALTER TABLE < 表名 > ADD COLUMN < 列的定义 >;
- 删除列
ALTER TABLE < 表名 > DROP COLUMN < 列名 >;
2.5.5 列数据更新:update+set
UPDATE <表名>
SET <列名> = <表达式> [, <列名2>=<表达式2>...]
WHERE <条件> -- 可选,非常重要。
ORDER BY 子句 --可选
LIMIT 子句 --可选
- 单列更新
-- 修改所有的注册时间
UPDATE product
SET regist_date = '2009-10-10';
-- 仅修改部分商品的单价
UPDATE product
SET sale_price = sale_price * 10
WHERE product_type = '厨房用具';
-- 将商品编号为0008的数据(圆珠笔)的登记日期更新为NULL
-- 只有未设置 NOT NULL 约束和主键约束的列才可以清空为NULL
UPDATE product
SET regist_date = NULL
WHERE product_id = '0008';
- 多列更新
-- 合并后的写法
UPDATE product
SET sale_price = sale_price * 10,
purchase_price = purchase_price / 2
WHERE product_type = '厨房用具';
2.5.6 清空表内容:truncate
TRUNCATE TABLE TABLE_NAME;
-- 小写
truncate table <表名>;
3 练习
- 3.1
- 3.2