实例-MySQL-模拟京东电商数据库

传智黑马Python37例子 自学中在网上找的视屏看,算是小白吧!没有其他的学习方法,之前看了一边,后面有看了一遍,把课中代码打了一边。 如果你有什么好方法赶紧给我分享啊!

MySQL操作

第一节:在mysql中操作例子

一. 创建

create database jing_dong charset=utf8;
use jing_dong
create table goods( id int unsigned primary key auto_increment not null,
                   name varchar(150) not null, 
                   cate_name varchar(40) not null,
                   brand_name varchar(40) not null, 
                   price decimal(10.3) not null default 0,
                   is_show bit not null default 1, 
                   is_saleoff bit not null default 0 
                  );

二. 导入

insert into goods values(0,'r510vc 15.6英寸笔记本','笔记本','华硕','3399',default,default);
insert into goods values(0,'x550cc 15.6英寸笔记本','笔记本','华硕','2799',default,default);
insert into goods values(0,'x240 超极本','超极本','联想','4880',default,default);
insert into goods values(0,'u330p 13.3英寸超级本','超极本','联想','4299',default,default);
insert into goods values(0,'svp13226scb 触控超级本','超级本','索尼','7999',default,default);
insert into goods values(0,'ipad mini 7.9英寸平板电脑','平板电脑','苹果','1999',default,default);
insert into goods values(0,'iPad air 9.7英寸平板电脑','平板电脑','苹果','3388',default,default);
insert into goods values(0,'iPad mini 配置 retine 显示屏','平板电脑','苹果','2788',default,default);
insert into goods values(0,'ideacentre c3340 20英寸一体电脑','台式机','联想','3499',default,default);
insert into goods values(0,'vostro 3800-r1206 台式电脑','台式机','戴尔','2899',default,default);
insert into goods values(0,'15.6 寸电脑屏保护膜','电脑配件','爱戴尔','29',default,default);
insert into goods values(0,'优雅 复古 无线鼠标键盘','电脑配件','雷蛇','299',default,default);
insert into goods values(0,'15寸 4K 液晶显示屏','电脑配件','索尼','1899',default,default);
insert into goods values(0,'限量款 LOL 鼠标垫','电脑配件','唯爱','29',default,default);

三. 查询

1.简单查询
mysql> select id as 编号,name as 商品名称,cate_name as 类型,brand_name as 品牌,price as 价钱 from goods as 商品表;
+--------+---------------------------------------+--------------+-----------+--------+
| 编号   | 商品名称                              | 类型         | 品牌      | 价钱   |
+--------+---------------------------------------+--------------+-----------+--------+
|      1 | r510vc 15.6英寸笔记本                 | 笔记本       | 华硕      |   3399 |
|      2 | x550cc 15.6英寸笔记本                 | 笔记本       | 华硕      |   2799 |
|      3 | x240 超极本                           | 超极本       | 联想      |   4880 |
|      4 | u330p 13.3英寸超级本                  | 超极本       | 联想      |   4299 |
|      5 | svp13226scb 触控超级本                | 超级本       | 索尼      |   7999 |
|      6 | ipad mini 7.9英寸平板电脑             | 平板电脑     | 苹果      |   1999 |
|      7 | iPad air 9.7英寸平板电脑              | 平板电脑     | 苹果      |   3388 |
|      8 | iPad mini 配置 retine 显示屏          | 平板电脑     | 苹果      |   2788 |
|      9 | ideacentre c3340 20英寸一体电脑       | 台式机       | 联想      |   3499 |
|     10 | vostro 3800-r1206 台式电脑            | 台式机       | 戴尔      |   2899 |
|     11 | 15.6 寸电脑屏保护膜                   | 电脑配件     | 爱戴尔    |     29 |
|     12 | 优雅 复古 无线鼠标键盘                | 电脑配件     | 雷蛇      |    299 |
|     13 | 15寸 4K 液晶显示屏                    | 电脑配件     | 索尼      |   1899 |
|     14 | 限量款 LOL 鼠标垫                     | 电脑配件     | 唯爱      |     29 |
+--------+---------------------------------------+--------------+-----------+--------+
14 rows in set (0.00 sec)
mysql> select id as 编号,name as 商品名称,price as 价钱,brand_name as 品牌,cate_name as 类型 from goods as 商品表  where cate_name='笔记本';
+--------+----------------------------+--------+--------+-----------+
| 编号   | 商品名称                   | 价钱   | 品牌   | 类型      |
+--------+----------------------------+--------+--------+-----------+
|      1 | r510vc 15.6英寸笔记本      |   3399 | 华硕   | 笔记本    |
|      2 | x550cc 15.6英寸笔记本      |   2799 | 华硕   | 笔记本    |
+--------+----------------------------+--------+--------+-----------+
2 rows in set (0.00 sec)

mysql> select id as 编号,name as 商品名称,price as 价钱,brand_name as 品牌,cate_name as 类型 from goods as 商品表  where 类型='笔记本';
ERROR 1054 (42S22): Unknown column '类型' in 'where clause'


mysql> select id as 编号,name as 商品名称,price as 价钱,brand_name as 品牌,cate_name as cate from goods as 商品表  where cate='笔记本';
ERROR 1054 (42S22): Unknown column 'cate' in 'where clause'

2.属性查询 与其他
mysql> select distinct brand_name from goods;
+------------+
| brand_name |
+------------+
| 华硕       |
| 联想       |
| 索尼       |
| 苹果       |
| 戴尔       |
| 爱戴尔     |
| 雷蛇       | 
| 唯爱       |
+------------+
8 rows in set (0.00 sec)

-- 与 distinct 相似
mysql> select brand_name from goods group by cate_name;
+------------+
| brand_name |
+------------+
| 华硕       |
| 唯爱       |
| 戴尔       |
| 爱戴尔     |
| 索尼       |
| 联想       |
| 苹果       |
| 雷蛇       |
+------------+
8 rows in set (0.01 sec)

-- 相比 distinct 功能较多
mysql> select brand_name,group_concat(id) from goods group by brand_name;
+------------+------------------+
| brand_name | group_concat(id) |
+------------+------------------+
| 华硕       | 1,2              |
| 唯爱       | 14               |
| 戴尔       | 10               |
| 爱戴尔     | 11               |
| 索尼       | 5,13             |
| 联想       | 3,4,9            |
| 苹果       | 6,7,8            |
| 雷蛇       | 12               |
+------------+------------------+
8 rows in set (0.28 sec)

-- 可用 as
mysql> select brand_name,group_concat(id) as group_id from goods group by branby brand_name;
+------------+----------+
| brand_name | group_id |
+------------+----------+
| 华硕       | 1,2      |
| 唯爱       | 14       |
| 戴尔       | 10       |
| 爱戴尔     | 11       |
| 索尼       | 5,13     |
| 联想       | 3,4,9    |
| 苹果       | 6,7,8    |
| 雷蛇       | 12       |
+------------+----------+
8 rows in set (0.00 sec)
3.最值查询
-- 求平均值
mysql> select avg(price) from goods;
+------------+
| avg(price) |xiangsi
+------------+
|  2871.7857 |
+------------+
1 row in set (0.00 sec)

-- 保留两有效数字   #在以后实际开发的时候,尽量不要用小数,一般是放大10N倍存入,使用时在除
mysql> select round(avg(price),2) from goods;
+---------------------+
| round(avg(price),2) |
+---------------------+
|             2871.79 |
+---------------------+
1 row in set (0.00 sec)



-- 这有个问题,group_concat 不能这么用
mysql> select brand_name,group_concat(avg(price)) from goods group by brand_name;
ERROR 1111 (HY000): Invalid use of group function

mysql> select brand_name,avg(price) from goods group by brand_name;
+------------+------------+
| brand_name | avg(price) |
+------------+------------+
| 华硕       |  3099.0000 |
| 唯爱       |    29.0000 |
| 戴尔       |  2899.0000 |
| 爱戴尔     |    29.0000 |
| 索尼       |  4949.0000 |
| 联想       |  4226.0000 |
| 苹果       |  2725.0000 |
| 雷蛇       |   299.0000 |
+------------+------------+
8 rows in set (0.00 sec)


-- 查询 多类 平均,最贵,最便宜,几个
mysql> select brand_name,avg(price),max(price),min(price),count(*) from goods group by brand_name;
+------------+------------+------------+------------+----------+
| brand_name | avg(price) | max(price) | min(price) | count(*) |
+------------+------------+------------+------------+----------+
| 华硕       |  3099.0000 |       3399 |       2799 |        2 |
| 唯爱       |    29.0000 |         29 |         29 |        1 |
| 戴尔       |  2899.0000 |       2899 |       2899 |        1 |
| 爱戴尔     |    29.0000 |         29 |         29 |        1 |
| 索尼       |  4949.0000 |       7999 |       1899 |        2 |
| 联想       |  4226.0000 |       4880 |       3499 |        3 |
| 苹果       |  2725.0000 |       3388 |       1999 |        3 |
| 雷蛇       |   299.0000 |        299 |        299 |        1 |
+------------+------------+------------+------------+----------+
8 rows in set (0.00 sec)

-- 小于平均价格的
mysql> select * from goods where price < (select avg(price) from goods);
+----+-----------------------------------+--------------+------------+-------+---------+------------+
| id | name                              | cate_name    | brand_name | price | is_show | is_saleoff |
+----+-----------------------------------+--------------+------------+-------+---------+------------+
|  2 | x550cc 15.6英寸笔记本             | 笔记本       | 华硕       |  2799 | �       |            |
|  6 | ipad mini 7.9英寸平板电脑         | 平板电脑     | 苹果       |  1999 | �       |            |
|  8 | iPad mini 配置 retine 显示屏      | 平板电脑     | 苹果       |  2788 | �       |            |
| 11 | 15.6 寸电脑屏保护膜               | 电脑配件     | 爱戴尔     |    29 | �       |            |
| 12 | 优雅 复古 无线鼠标键盘            | 电脑配件     | 雷蛇       |   299 | �       |            |
| 13 | 15寸 4K 液晶显示屏                | 电脑配件     | 索尼       |  1899 | �       |            |
| 14 | 限量款 LOL 鼠标垫                 | 电脑配件     | 唯爱       |    29 | �       |            |
+----+-----------------------------------+--------------+------------+-------+---------+------------+
7 rows in set (0.00 sec)
4.进阶 查询 join
-- 使用 left join  查询每类(品牌)最贵的商品信息

-- 第一:
mysql> select brand_name,max(price) as max_price from goods group by brand_name;
+------------+-----------+
| brand_name | max_price |
+------------+-----------+
| 华硕       |      3399 |
| 唯爱       |        29 |
| 戴尔       |      2899 |
| 爱戴尔     |        29 |
| 索尼       |      7999 |
| 联想       |      4880 |
| 苹果       |      3388 |
| 雷蛇       |       299 |
+------------+-----------+
8 rows in set (0.47 sec)
-- ×代码
select * 
from (select brand_name,max(price) as max_price from goods group by brand_name) as b_new
left join goods as g 
on b_new.brand_name=g.brand_name and b_new.max_price=g.price;

mysql> select * 
    -> from (select brand_name,max(price) as max_price from goods group by brand_name) as b_new
    -> left join goods as g 
    -> on b_new.brand_name=g.brand_name and b_new.max_price=g.price;
+------------+-----------+------+----------------------------------+--------------+------------+-------+---------+------------+
| brand_name | max_price | id   | name                             | cate_name    | brand_name | price | is_show | is_saleoff |
+------------+-----------+------+----------------------------------+--------------+------------+-------+---------+------------+
| 华硕       |      3399 |    1 | r510vc 15.6英寸笔记本            | 笔记本       | 华硕       |  3399 | �       |            |
| 联想       |      4880 |    3 | x240 超极本                      | 超极本       | 联想       |  4880 | �       |            |
| 索尼       |      7999 |    5 | svp13226scb 触控超级本           | 超级本       | 索尼       |  7999 | �       |            |
| 苹果       |      3388 |    7 | iPad air 9.7英寸平板电脑         | 平板电脑     | 苹果       |  3388 | �       |            |
| 戴尔       |      2899 |   10 | vostro 3800-r1206 台式电脑       | 台式机       | 戴尔       |  2899 | �       |            |
| 爱戴尔     |        29 |   11 | 15.6 寸电脑屏保护膜              | 电脑配件     | 爱戴尔     |    29 | �       |            |
| 雷蛇       |       299 |   12 | 优雅 复古 无线鼠标键盘           | 电脑配件     | 雷蛇       |   299 | �       |            |
| 唯爱       |        29 |   14 | 限量款 LOL 鼠标垫                | 电脑配件     | 唯爱       |    29 | �       |            |
+------------+-----------+------+----------------------------------+--------------+------------+-------+---------+------------+
8 rows in set (0.00 sec)
5.其他

四.修改

1.拆表

拆表 与其他有关操作


-- 拆表 将商品类型 和 商品品牌 拆出成新的表格

-- 1.新建 table (一个goods_cates 一个goods_brands)

mysql> create table if not exists goods_cates(
    -> id int unsigned primary key auto_increment,
    -> name varchar(40) not null
    -> );
Query OK, 0 rows affected (0.49 sec)

mysql> create table if not exists goods_brands( 
    -< id int unsigned primary key auto_increment, 
    -< name varchar(40) not null );
Query OK, 0 rows affected (0.35 sec)

mysql> show tables;
+---------------------+
| Tables_in_jing_dong |
+---------------------+
| goods               |
| goods_brands        |
| goods_cates         |
+---------------------+
3 rows in set (0.00 sec)

-- 2. 添加信息
mysql> insert into goods_cates (name) select cate_name from goods group by cate_name;
Query OK, 6 rows affected (0.07 sec)
Records: 6  Duplicates: 0  Warnings: 0

mysql> insert into goods_brands (name) select brand_name from goods group by brand_name;
Query OK, 8 rows affected (0.06 sec)
Records: 8  Duplicates: 0  Warnings: 0

mysql> select * from goods_cates;
+----+--------------+
| id | name         |
+----+--------------+
|  1 | 台式机       |
|  2 | 平板电脑     |
|  3 | 电脑配件     |
|  4 | 笔记本       |
|  5 | 超极本       |
|  6 | 超级本       |
+----+--------------+
6 rows in set (0.00 sec)

mysql> select * from goods_brands;
+----+-----------+
| id | name      |
+----+-----------+
|  1 | 华硕      |
|  2 | 唯爱      |
|  3 | 戴尔      |
|  4 | 爱戴尔    |
|  5 | 索尼      |
|  6 | 联想      |
|  7 | 苹果      |
|  8 | 雷蛇      |
+----+-----------+
8 rows in set (0.00 sec)

-- 3.换参数
-- 将 goods表中的cate_name 换成goods_cates 的id
mysql> mysql> update goods as g inner join goods_cates as c on g.cate_name=c.name set g.cate_name=c.id;
Query OK, 14 rows affected (0.07 sec)
Rows matched: 14  Changed: 14  Warnings: 0

mysql> select * from goods;
+----+---------------------------------------+-----------+------------+-------+---------+------------+
| id | name                                  | cate_name | brand_name | price | is_show | is_saleoff |
+----+---------------------------------------+-----------+------------+-------+---------+------------+
|  1 | r510vc 15.6英寸笔记本                 | 4         | 华硕       |  3399 | �       |            |
|  2 | x550cc 15.6英寸笔记本                 | 4         | 华硕       |  2799 | �       |            |
|  3 | x240 超极本                           | 5         | 联想       |  4880 | �       |            |
|  4 | u330p 13.3英寸超级本                  | 5         | 联想       |  4299 | �       |            |
|  5 | svp13226scb 触控超级本                | 6         | 索尼       |  7999 | �       |            |
|  6 | ipad mini 7.9英寸平板电脑             | 2         | 苹果       |  1999 | �       |            |
|  7 | iPad air 9.7英寸平板电脑              | 2         | 苹果       |  3388 | �       |            |
|  8 | iPad mini 配置 retine 显示屏          | 2         | 苹果       |  2788 | �       |            |
|  9 | ideacentre c3340 20英寸一体电脑       | 1         | 联想       |  3499 | �       |            |
| 10 | vostro 3800-r1206 台式电脑            | 1         | 戴尔       |  2899 | �       |            |
| 11 | 15.6 寸电脑屏保护膜                   | 3         | 爱戴尔     |    29 | �       |            |
| 12 | 优雅 复古 无线鼠标键盘                | 3         | 雷蛇       |   299 | �       |            |
| 13 | 15寸 4K 液晶显示屏                    | 3         | 索尼       |  1899 | �       |            |
| 14 | 限量款 LOL 鼠标垫                     | 3         | 唯爱       |    29 | �       |            |
+----+---------------------------------------+-----------+------------+-------+---------+------------+
14 rows in set (0.00 sec)

-- 将goods表中的 brands_name 换成 goods_brands中的id
mysql> update goods as g inner join goods_brands as b on g.brand_name=b.name set g.brand_name=b.id;
Query OK, 14 rows affected (0.05 sec)
Rows matched: 14  Changed: 14  Warnings: 0

mysql> select * from goods;
+----+---------------------------------------+-----------+------------+-------+---------+------------+
| id | name                                  | cate_name | brand_name | price | is_show | is_saleoff |
+----+---------------------------------------+-----------+------------+-------+---------+------------+
|  1 | r510vc 15.6英寸笔记本                 | 4         | 1          |  3399 | �       |            |
|  2 | x550cc 15.6英寸笔记本                 | 4         | 1          |  2799 | �       |            |
|  3 | x240 超极本                           | 5         | 6          |  4880 | �       |            |
|  4 | u330p 13.3英寸超级本                  | 5         | 6          |  4299 | �       |            |
|  5 | svp13226scb 触控超级本                | 6         | 5          |  7999 | �       |            |
|  6 | ipad mini 7.9英寸平板电脑             | 2         | 7          |  1999 | �       |            |
|  7 | iPad air 9.7英寸平板电脑              | 2         | 7          |  3388 | �       |            |
|  8 | iPad mini 配置 retine 显示屏          | 2         | 7          |  2788 | �       |            |
|  9 | ideacentre c3340 20英寸一体电脑       | 1         | 6          |  3499 | �       |            |
| 10 | vostro 3800-r1206 台式电脑            | 1         | 3          |  2899 | �       |            |
| 11 | 15.6 寸电脑屏保护膜                   | 3         | 4          |    29 | �       |            |
| 12 | 优雅 复古 无线鼠标键盘                | 3         | 8          |   299 | �       |            |
| 13 | 15寸 4K 液晶显示屏                    | 3         | 5          |  1899 | �       |            |
| 14 | 限量款 LOL 鼠标垫                     | 3         | 2          |    29 | �       |           |
+----+---------------------------------------+-----------+------------+-------+---------+------------+
14 rows in set (0.00 sec)


-- 向goods_cates 添加 数据 (goods_brand)
mysql> insert into goods_cates(name) values ('路由器'),('交换机'),('网卡');
Query OK, 3 rows affected (0.06 sec)
Records: 3  Duplicates: 0  Warnings: 0

mysql> select *  from goods_cates;
+----+--------------+
| id | name         |
+----+--------------+
|  1 | 台式机       |
|  2 | 平板电脑     |
|  3 | 电脑配件     |
|  4 | 笔记本       |
|  5 | 超极本       |
|  6 | 超级本       |
|  8 | 路由器       |
|  9 | 交换机       |
| 10 | 网卡         |
+----+--------------+
9 rows in set (0.00 sec)

mysql> insert into goods_brands(name) values ('海尔'),('清华同方'),('神舟');
Query OK, 3 rows affected (0.05 sec)
Records: 3  Duplicates: 0  Warnings: 0


-- 向主表添加数据(发现有问题 cate_name,brand_name 超出goods_cates 和 goods_brands 不会报错)
mysql> insert into goods (name,cate_name,brand_name,price) values('LaserJet Pro P1600dn 黑白打印机','12','10','1988');
Query OK, 1 row affected (0.06 sec)

mysql> select * from goods;
+----+---------------------------------------+-----------+------------+-------+---------+------------+
| id | name                                  | cate_name | brand_name | price | is_show | is_saleoff |
+----+---------------------------------------+-----------+------------+-------+---------+------------+
|  1 | r510vc 15.6英寸笔记本                 | 4         | 1          |  3399 | �       |            |
|  2 | x550cc 15.6英寸笔记本                 | 4         | 1          |  2799 | �       |            |
|  3 | x240 超极本                           | 5         | 6          |  4880 | �       |            |
|  4 | u330p 13.3英寸超级本                  | 5         | 6          |  4299 | �       |            |
|  5 | svp13226scb 触控超级本                | 6         | 5          |  7999 | �       |            |
|  6 | ipad mini 7.9英寸平板电脑             | 2         | 7          |  1999 | �       |            |
|  7 | iPad air 9.7英寸平板电脑              | 2         | 7          |  3388 | �       |            |
|  8 | iPad mini 配置 retine 显示屏          | 2         | 7          |  2788 | �       |            |
|  9 | ideacentre c3340 20英寸一体电脑       | 1         | 6          |  3499 | �       |            |
| 10 | vostro 3800-r1206 台式电脑            | 1         | 3          |  2899 | �       |            |
| 11 | 15.6 寸电脑屏保护膜                   | 3         | 4          |    29 | �       |            |
| 12 | 优雅 复古 无线鼠标键盘                | 3         | 8          |   299 | �       |            |
| 13 | 15寸 4K 液晶显示屏                    | 3         | 5          |  1899 | �       |            |
| 14 | 限量款 LOL 鼠标垫                     | 3         | 2          |    29 | �       |            |
| 15 | LaserJet Pro P1600dn 黑白打印机       | 12        | 10         |  1988 | �       |            |
+----+---------------------------------------+-----------+------------+-------+---------+------------+
15 rows in set (0.00 sec)

-- 发现cate_name 和 brand_name(字符)存储的是(int)
mysql> desc goods;
+------------+------------------+------+-----+---------+----------------+
| Field      | Type             | Null | Key | Default | Extra          |
+------------+------------------+------+-----+---------+----------------+
| id         | int(10) unsigned | NO   | PRI | NULL    | auto_increment |
| name       | varchar(150)     | NO   |     | NULL    |                |
| cate_name  | varchar(40)      | NO   |     | NULL    |                |
| brand_name | varchar(40)      | NO   |     | NULL    |                |
| price      | decimal(10,0)    | NO   |     | 0       |                |
| is_show    | bit(1)           | NO   |     | b'1'    |                |
| is_saleoff | bit(1)           | NO   |     | b'0'    |                |
+------------+------------------+------+-----+---------+----------------+
7 rows in set (0.03 sec)
mysql> desc goods_cates;
+-------+------------------+------+-----+---------+----------------+
| Field | Type             | Null | Key | Default | Extra          |
+-------+------------------+------+-----+---------+----------------+
| id    | int(10) unsigned | NO   | PRI | NULL    | auto_increment |
| name  | varchar(40)      | NO   |     | NULL    |                |
+-------+------------------+------+-----+---------+----------------+
2 rows in set (0.00 sec)

mysql> desc goods_brands;
+-------+------------------+------+-----+---------+----------------+
| Field | Type             | Null | Key | Default | Extra          |
+-------+------------------+------+-----+---------+----------------+
| id    | int(10) unsigned | NO   | PRI | NULL    | auto_increment |
| name  | varchar(40)      | NO   |     | NULL    |                |
+-------+------------------+------+-----+---------+----------------+
2 rows in set (0.00 sec)


-- 修改 cate_name 为 cate_id (int) 和 brand_name 为 brand_id(int)
mysql> alter  table goods change cate_name cate_id int unsigned not null;
Query OK, 15 rows affected (1.08 sec)
Records: 15  Duplicates: 0  Warnings: 0
mysql> desc goods;
+------------+------------------+------+-----+---------+----------------+
| Field      | Type             | Null | Key | Default | Extra          |
+------------+------------------+------+-----+---------+----------------+
| id         | int(10) unsigned | NO   | PRI | NULL    | auto_increment |
| name       | varchar(150)     | NO   |     | NULL    |                |
| cate_id    | int(10) unsigned | NO   |     | NULL    |                |
| brand_name | varchar(40)      | NO   |     | NULL    |                |
| price      | decimal(10,0)    | NO   |     | 0       |                |
| is_show    | bit(1)           | NO   |     | b'1'    |                |
| is_saleoff | bit(1)           | NO   |     | b'0'    |                |
+------------+------------------+------+-----+---------+----------------+
7 rows in set (0.00 sec)

mysql> alter table goods change brand_name brand_id int unsigned not null;
Query OK, 15 rows affected (0.92 sec)
Records: 15  Duplicates: 0  Warnings: 0
2.设置外键
-- 关联三个表,设置外键
mysql> alter table goods add foreign key (cate_id) references goods_cates(id);
ERROR 1452 (23000): Cannot add or update a child row: a foreign key constraint fails (`jing_dong`.`#sql-438_2`, CONSTRAINT `#sql-438_2_ibfk_1` FOREIGN KEY (`cate_id`) REFERENCES `goods_cates` (`id`))
-- 由于之前添加了 cate_name=12 不在goods_cates中才报错,下面将此信息删除掉
mysql> delete from goods where id=15;
Query OK, 1 row affected (0.04 sec)

mysql> alter table goods add foreign key (cate_id) references goods_cates(id);
Query OK, 14 rows affected (1.32 sec)
Records: 14  Duplicates: 0  Warnings: 0
mysql> alter table goods add foreign key (brand_id) references goods_brands(id);
Query OK, 14 rows affected (1.21 sec)
Records: 14  Duplicates: 0  Warnings: 0


-- 在添加一个 外键值以外的数据 发现会出错,这就会减少数据输错的可能
mysql> insert into goods (name,cate_id,brand_id,price) values('LaserJet Pro P1600dn 黑白打印机','12','10','1988');
ERROR 1452 (23000): Cannot add or update a child row: a foreign key constraint fails (`jing_dong`.`goods`, CONSTRAINT `goods_ibfk_1` FOREIGN KEY (`cate_id`) REFERENCES `goods_cates` (`id`))

-- 查看是否添加成功外键    下表  CONSTRAINT(约束,限制)后
mysql> show create table goods;
+-------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table    |
+-------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| goods | CREATE TABLE `goods` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `name` varchar(150) NOT NULL,
  `cate_id` int(10) unsigned NOT NULL,
  `brand_id` int(10) unsigned NOT NULL,
  `price` decimal(10,0) NOT NULL DEFAULT '0',
  `is_show` bit(1) NOT NULL DEFAULT b'1',
  `is_saleoff` bit(1) NOT NULL DEFAULT b'0',
  PRIMARY KEY (`id`),
  KEY `cate_id` (`cate_id`),
  KEY `brand_id` (`brand_id`),
  CONSTRAINT `goods_ibfk_1` FOREIGN KEY (`cate_id`) REFERENCES `goods_cates` (`id`),
  CONSTRAINT `goods_ibfk_2` FOREIGN KEY (`brand_id`) REFERENCES `goods_brands` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=18 DEFAULT CHARSET=utf8 |
+-------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

五.备份

在 shell 中执行下面的命令

╭─python@b  ~/Documents/notebook/MySQL学习笔记
╰─$ mysqldump -uroot -pohmysql jing_dong > jd.sql
mysqldump: [Warning] Using a password on the command line interface can be insecure.
╭─python@b  ~/Documents/notebook/MySQL学习笔记 
╰─$ ls
 jd.sql               'mysq基础操作(命令).md'   ubuntu下mysql连接问题.md     数据

备份出的文件( jd.sql )长这样,不就是mysql 的命令吗?

-- MySQL dump 10.13  Distrib 5.7.25, for Linux (x86_64)
--
-- Host: localhost    Database: jing_dong
-- ------------------------------------------------------
-- Server version   5.7.25-0ubuntu0.18.04.2

/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8 */;
/*!40103 SET @OLD_TIME_ZONE=@@TIME_ZONE */;
/*!40103 SET TIME_ZONE='+00:00' */;
/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;

--
-- Table structure for table `goods`
--

DROP TABLE IF EXISTS `goods`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `goods` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `name` varchar(150) NOT NULL,
  `cate_id` int(10) unsigned NOT NULL,
  `brand_id` int(10) unsigned NOT NULL,
  `price` decimal(10,0) NOT NULL DEFAULT '0',
  `is_show` bit(1) NOT NULL DEFAULT b'1',
  `is_saleoff` bit(1) NOT NULL DEFAULT b'0',
  PRIMARY KEY (`id`),
  KEY `cate_id` (`cate_id`),
  KEY `brand_id` (`brand_id`),
  CONSTRAINT `goods_ibfk_1` FOREIGN KEY (`cate_id`) REFERENCES `goods_cates` (`id`),
  CONSTRAINT `goods_ibfk_2` FOREIGN KEY (`brand_id`) REFERENCES `goods_brands` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=15 DEFAULT CHARSET=utf8;
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `goods`
--

LOCK TABLES `goods` WRITE;
/*!40000 ALTER TABLE `goods` DISABLE KEYS */;
INSERT INTO `goods` VALUES (1,'r510vc 15.6英寸笔记本',4,1,3399,_binary '�',_binary '\0'),(2,'x550cc 15.6英寸笔记本',4,1,2799,_binary '�',_binary '\0'),(3,'x240 超极本',5,6,4880,_binary '�',_binary '\0'),(4,'u330p 13.3英寸超级本',5,6,4299,_binary '�',_binary '\0'),(5,'svp13226scb 触控超级本',6,5,7999,_binary '�',_binary '\0'),(6,'ipad mini 7.9英寸平板电脑',2,7,1999,_binary '�',_binary '\0'),(7,'iPad air 9.7英寸平板电脑',2,7,3388,_binary '�',_binary '\0'),(8,'iPad mini 配置 retine 显示屏',2,7,2788,_binary '�',_binary '\0'),(9,'ideacentre c3340 20英寸一体电脑',1,6,3499,_binary '�',_binary '\0'),(10,'vostro 3800-r1206 台式电脑',1,3,2899,_binary '�',_binary '\0'),(11,'15.6 寸电脑屏保护膜',3,4,29,_binary '�',_binary '\0'),(12,'优雅 复古 无线鼠标键盘',3,8,299,_binary '�',_binary '\0'),(13,'15寸 4K 液晶显示屏',3,5,1899,_binary '�',_binary '\0'),(14,'限量款 LOL 鼠标垫',3,2,29,_binary '�',_binary '\0');
/*!40000 ALTER TABLE `goods` ENABLE KEYS */;
UNLOCK TABLES;

--
-- Table structure for table `goods_brands`
--

DROP TABLE IF EXISTS `goods_brands`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `goods_brands` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `name` varchar(40) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=19 DEFAULT CHARSET=utf8;
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `goods_brands`
--

LOCK TABLES `goods_brands` WRITE;
/*!40000 ALTER TABLE `goods_brands` DISABLE KEYS */;
INSERT INTO `goods_brands` VALUES (1,'华硕'),(2,'唯爱'),(3,'戴尔'),(4,'爱戴尔'),(5,'索尼'),(6,'联想'),(7,'苹果'),(8,'雷蛇'),(16,'海尔'),(17,'清华同方'),(18,'神舟');
/*!40000 ALTER TABLE `goods_brands` ENABLE KEYS */;
UNLOCK TABLES;

--
-- Table structure for table `goods_cates`
--

DROP TABLE IF EXISTS `goods_cates`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `goods_cates` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `name` varchar(40) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8;
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `goods_cates`
--

LOCK TABLES `goods_cates` WRITE;
/*!40000 ALTER TABLE `goods_cates` DISABLE KEYS */;
INSERT INTO `goods_cates` VALUES (1,'台式机'),(2,'平板电脑'),(3,'电脑配件'),(4,'笔记本'),(5,'超极本'),(6,'超级本'),(8,'路由器'),(9,'交换机'),(10,'网卡');
/*!40000 ALTER TABLE `goods_cates` ENABLE KEYS */;
UNLOCK TABLES;
/*!40103 SET TIME_ZONE=@OLD_TIME_ZONE */;

/*!40101 SET SQL_MODE=@OLD_SQL_MODE */;
/*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */;
/*!40014 SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS */;
/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;
/*!40111 SET SQL_NOTES=@OLD_SQL_NOTES */;

-- Dump completed on 2019-04-23 14:54:00

备份数据库所有数据

mysqldump -uroot -pmysql --all-databases --lock-all-tables > ~/master_db.sql

六.附录

1.资料

课上老师推荐课外资料 58到家数据库30条军规

第二节:用Python操作

用的是 pymysql

一.查询

大概流程如下

修改 sql 中的命令就可实现不同功能了

from pymysql import connect
conn = connect(host = 'localhost', port = 3306,
            user = 'root', password = 'ohmysql',
            database = 'jing_dong', charset = 'utf8')


# 获得Cursor对象  (游标)
cursor = conn.cursor()
sql = "select * from goods limit 20;"
cursor.execute(sql)
#fetchall() 查询全部; fetchmany(n)查询n个; fetchone()查询一个
for i in cursor.fetchone():
    print(i)

#断开连接
cursor.close()
conn.close()

二.增删改

增删改 的过程 与查询过程 相似 (修改sql 中的语句就可实现不同功能)

唯一不同就是,命令 和 多了一步 确定 环节

#执行后,mysql才对进行操作   就是yes
conn.commit()
#执行后,放弃操作,不会进行    no
conn.rollback()
In [1]: from pymysql import connect 
   ...:  
   ...: # 创建Connect连接 
   ...: conn = connect(host = 'localhost', port = 3306, 
   ...:     user = 'root', password = 'ohmysql', 
   ...:     database = 'jing_dong', charset = 'utf8') 
   ...: # 获得Cursor对象  (游标) 
   ...: cursor = conn.cursor() 

    
In [2]: sql = "insert into goods_cates (name) values ("硬
   ...: 盘---> new") ;"                                      
  File "<ipython-input-2-69f27cbdfaa7>", line 1
    sql = "insert into goods_cates (name) values ("硬盘---> new") "
                                                      ^
SyntaxError: invalid syntax


In [3]: sql = """insert into goods_cates (name) values ("硬盘---> new");"""  

In [4]: cursor.execute(sql)                                                             Out[4]: 1

In [5]: conn.commit()

In [6]: sql = """insert into goods_cates (name) values ("内存条---> new");"""                  
In [7]: cursor.execute(sql)                                                             Out[5]: 1

In [10]: conn.rollback() 

没有执行 commit 和 rollback 时 MySQL中 的AUTO_INCREMENT=11 会变化 (MySQL 语句不会执行)

mysql> show create table goods_cates;
+-------------+------------------------------------------------------------------------------------------------+
| Table       | Create Table   |
+-------------+------------------------------------------------------------------------------------------------+
| goods_cates | CREATE TABLE `goods_cates` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `name` varchar(40) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8 |
+-------------+------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

三.示例代码

面对对象思想,对不同功能进行封装

from pymysql import connect

class JD(object):
    def __init__(self):
        # 创建Connection连接
        self.conn = connect(host = 'localhost', port = 3306,
            user = 'root', password = 'ohmysql',
            database = 'jing_dong', charset = 'utf8')
        # 获得Cursor对象  (游标)
        self.cursor = self.conn.cursor()

    def __del__(self):
        # 关闭Cursor对象
        self.cursor.close()
        self.conn.close()

    def execute_sql(self, sql):
        self.cursor.execute(sql)
        for temp in self.cursor.fetchall():
            print(temp)
        print()

    def show_all_items(self):
        '''显示所有的商品'''
        sql = "select * from goods;"
        self.execute_sql(sql) 
    
    def show_cates(self):
        # 显示所有商品种类
        sql = "select name from goods_cates;"
        self.execute_sql(sql)

    def show_brands(self):
        # 显示所有商品品牌
        sql = "select name from goods_brands;"
        self.execute(sql)

    def add_brands(self):
        item_name = input("输入新商品名称: ")
        sql = """insert into goods_cates (name) values("%s")""" % item_name
        self.cursor.execute(sql)
        self.conn.commit()

    @staticmethod
    def print_menu():
        print("-------> 京东 <-------")
        print("1.所有商品")
        print("2.所有商品分类")
        print("3.所有商品品牌")
        print("4.添加商品分类")
        print()
        return input("请输入你要查询的信息 :")


    def run(self):
        while True:
            num = self.print_menu()
            if num == "1":
                # 查询所有商品
                self.show_all_items()
            elif num == "2":
                # 查询所有商品分类
                self.show_cates()
            elif num == "3":
                # 查询所有商品牌
                self.show_brands()
            elif num == "4":
                # 增加商品分类
                self.add_brands()
            else:
                print("输入有误,请重新输入你要查询的信息~~")

def main():
    # 创建一个京东对象
    jd = JD()

    # 调用这个对象的run方法
    jd.run()

if __name__ == '__main__':
    main()
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,186评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,858评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,620评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,888评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,009评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,149评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,204评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,956评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,385评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,698评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,863评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,544评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,185评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,899评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,141评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,684评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,750评论 2 351