MySQL学习笔记一:表的创建与操作、查询基础

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,中国工信出版社&人民邮电出版社

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值