SQL语句及种类
- DDL(Data Definition Language,数据定义语言)用来创建或者删除存储数据用的数据库以及数据库中的表等对象。DDL 包含以下几种指令:
- CREATE :创建数据库和表等对象
- DROP : 删除数据库和表等对象
- ALTER : 修改数据库和表等对象的结构
- DML(Data Manipulation Language,数据操纵语言) 用来查询或者变更表中的记录。实际使用的 SQL 语句当中有 90% 属于 DML。DML 包含以下几种指令:
- SELECT :查询表中的数据
- INSERT :向表中插入新数据
- UPDATE :更新表中的数据
- DELETE :删除表中的数据
- DCL(Data Control Language,数据控制语言) 用来确认或者取消对数据库中的数据进行的变更。除此之外,还可以对 RDBMS 的用户是否有权限操作数据库中的对象(数据库表等)进行设定。DCL 包含以下几种指令:
- COMMIT : 确认对数据库中的数据进行的变更
- ROLLBACK :取消对数据库中的数据进行的变更
- GRANT :赋予用户操作权限
- REVOKE:取消用户的操作权限
表的创建与操作(内容、删除、更新、修改)
1、假设要创造一个名为product的表,先创建用来存储表的数据库,取名为shop:
create database shop;-- 每一条语句分号结尾
双击schemas中的数据库名就可以进入该数据库。
2、创建product表,列名包括product_id,product_name,product_type ,sale_price,purchase_price,regist_date,各种约束设置如下:
CREATE TABLE product
(product_id CHAR(4) NOT NULL,-- CHAR指定长字符串,not null为非空
product_name VARCHAR(100) NOT NULL,-- VARCHAR指可变长字符串
product_type VARCHAR(32) NOT NULL,
sale_price INTEGER ,-- 整数
purchase_price INTEGER ,
regist_date DATE ,-- 日期
PRIMARY KEY (product_id));-- product_id为表的主键
3、insert into < table >(column1,column2,…) values (value1,value2,…) 向表中插入数据,有三种写法:
START TRANSACTION-- 事务开始语句,sql中可省略
INSERT INTO product VALUES ('0001', 'T恤' ,'衣服', 1000, 500, '2009-09-20');
INSERT INTO product VALUES ('0002', '打孔器', '办公用品', 500, 320, '2009-09-11');
INSERT INTO product VALUES ('0003', '运动T恤', '衣服', 4000, 2800, NULL),
('0004', '菜刀', '厨房用具', 3000, 2800, '2009-09-20'),
('0005', '高压锅', '厨房用具', 6800, 5000, '2009-01-15'),
('0006', '叉子', '厨房用具', 500, NULL, '2009-09-20'),
('0007', '擦菜板', '厨房用具', 880, 790, '2008-04-28');
INSERT INTO product(product_id,product_name,product_type,sale_price,regist_date)
VALUES ('0008', '圆珠笔', '办公用品', 100, '2009-11-11');-- 只插入这5列的数据
COMMIT;-- 事务确认处理语句,sql中可省略
注意想插入null的列不能有not null的约束;若某列没有not null的限制且不插入该列,那么此列数据为null(如上述第三种方法中purchase_price就是null)。
另外,如果对某一列设置了default,如果不插入该列数据那么就默认为default值,详细见MySQL笔记三。
4、查看表可以点击shop数据库中的product表格右边的第三个图标,或者输入:
SELECT * FROM shop.product;-- *和python一样代表全部
5、更新表的列:增添一列商品库存(约束为整数且非空),再删除:
alter table product add column product_kucun integer not null;
alter table product drop column product_kucun;
增加和删除多列时:
alter table product add MaleCount varchar(50) null,FemaleCount varchar(50) null;
alter table product drop MaleCount, drop FemaleCount;
语句中column可省略。
6、表名的修改:product改为Product:
alter table product rename to Product;
7、表和数据库的删除(不可恢复):
drop table product;
drop database shop;
查询基础:select (as) from (where)
8、为列设置别名,中文名称需要加引号,不更改原表格列名:
select product_id as id,product_name as '商品名称',purchase_price as price from product
9、基础花式查询:找出销售价格打九折之后利润(sale_price*0.9-purchase_price定义为profit列)高于100元的办公用品和厨房用具,并呈现出商品名称、商品类型和profit三列:
SELECT product_name,product_type,sale_price*0.9-purchase_price as profit FROM
product where sale_price*0.9-purchase_price>=100 and (product_type='办公用品'
or product_type='厨房用具');
注意and和or同时存在时考虑一下要不要加括号;SQL中的不等号表示为<>,等号为=,其余四则运算和比较运算符号与python无差异。
10、常数列的书写,包括字符串常数、数字常数、日期常数等:
select '商品' as string, 28 as number, '2019-02-09' as date,
product_id, product_name from product;
11、寻找唯一值:找出所有唯一的商品类型:
select distinct product_type from product;
注意如果有空值null也会输出当成一个唯一值。
12、寻找某一列有空值/没空值的记录:
select product_name,purchase_price from product where purchase_price is not null;
select product_name,purchase_price from product where not purchase_price is null;
-- not加在where后面也可以,表示条件的补集
13、单行注释用-- 或者#,多行注释用/* … */。
参考文献
SQL基础教程第2版,[日]MICK,中国工信出版社&人民邮电出版社