data:image/s3,"s3://crabby-images/bc91f/bc91f508c07a23dbfcff77f754b4e43ff55e394e" alt=""
data:image/s3,"s3://crabby-images/02df2/02df2508dc16355add2d59417cd35a4384b983d1" alt=""
把num值处于[20,29]之间,改为20;num值处于[30,39]之间的,改为30。
方法一:
update mian set num = 20 where num between 20 and 29;
update mian set num = 30 where num between 30 and 39;
方法二:
update mian set num = floor(num/10)*10 where num between 20 and 39;
data:image/s3,"s3://crabby-images/306cf/306cf024c676f2d4dfbec4e9db7c7ea0a005141e" alt=""
data:image/s3,"s3://crabby-images/1afdf/1afdf2de93c00a48a58b02d23dc041f9ebb8fc75" alt=""
data:image/s3,"s3://crabby-images/caa73/caa733eb408171e69a467f8ee414eab3daa1e613" alt=""
1、基础查询where的练习:
1.1、主键为32的商品
select goods_id, goods_name, shop_price,market_price from goods where goods_id = 32;
data:image/s3,"s3://crabby-images/e5745/e574572b840682edfa021929c0be7d3b5b1a5358" alt=""
1.2、不属第3栏目的所有商品
select goods_id, goods_name, cat_id, shop_price,market_price from goods where cat_id != 3;
data:image/s3,"s3://crabby-images/6061d/6061ded73e6282b917621b2cef6177c0f1d3fdad" alt=""
1.3、本店价格高于3000元的商品
select goods_id, goods_name, cat_id, shop_price,market_price from goods where shop_price > 3000;
data:image/s3,"s3://crabby-images/ff66f/ff66f21676a3f54298011c805bcf6fa969d7cc51" alt=""
1.4、本店价格低于或等于100元的商品
select goods_id, goods_name, cat_id, shop_price,market_price from goods where shop_price < 100;
data:image/s3,"s3://crabby-images/fa393/fa39372cb0b59da02076b8622d9c5cc47c29a547" alt=""
1.5、取出第4栏目或第11栏目的商品(不许用or)
select goods_id, goods_name, cat_id, shop_price,market_price from goods where cat_id in (4,11);
data:image/s3,"s3://crabby-images/07b0a/07b0a5627459250406c5d289096511e2ac5a5a52" alt=""
1.6、取出100<=价格<=500的商品(不许用and)
select goods_id, goods_name, cat_id, shop_price,market_price from goods where shop_price between 100 and 500;
data:image/s3,"s3://crabby-images/a4140/a41403d6b1c3546458a7e5e33517d5f64a6b37a2" alt=""
1.7、取出不属于第3栏目且不属于第11栏目的商品(and,或not in分别实现)
select goods_id, goods_name, cat_id, shop_price,market_price from goods where cat_id !=3 and cat_id !=11;
select goods_id, goods_name, cat_id, shop_price,market_price from goods where cat_id not in (3, 11);
data:image/s3,"s3://crabby-images/214eb/214eb46939aa3093e1ba3e25dd841e6e1c8fca97" alt=""
1.8、取出价格大于100且小于300,或者大于4000且小于5000的商品
select goods_id,cat_id,goods_name,shop_price from goods where shop_price > 100 and shop_price < 300 or shop_price > 4000 and shop_price < 5000;
data:image/s3,"s3://crabby-images/658a7/658a7805f7ff586294e11b3dd3dc9752f9401d9b" alt=""
1.9、取出第3个栏目下面价格<1000或>3000,并且点击量>5的系列商品
select goods_id,cat_id,goods_name,shop_price,click_count from goods where cat_id = 3 and (shop_price < 1000 or shop_price > 3000) and click_count > 5;
data:image/s3,"s3://crabby-images/13f81/13f81c352e16fa146996399320aaa31bb07c0839" alt=""
1.10、取出第1个栏目下面的商品(注意:1栏目下面没商品,但其子栏目下有)
栏目表如下图:
data:image/s3,"s3://crabby-images/b2451/b24516ad678706b0656d8d4c5f753241e64c695d" alt=""
题目中要取出栏目为1的商品,即cat_id为1的goods表中的商品。从表中可知cat_id 2~5的栏目均属于cat_id = 1的子栏目,所以这些要取出来。
# 建立一个视图保存从goods表中匹对出第1栏中的子栏商品
create view catid_1 as
-> select goods.cat_id, goods_name,category.parent_id, cat_name
-> from goods right join category
-> on goods.cat_id = category.cat_id and category.parent_id = 1;
data:image/s3,"s3://crabby-images/b3d9e/b3d9ee05aebb9eb227be78475cd095f0d7872148" alt=""
# 选出parent_id为1的商品即可
select parent_id, cat_id, goods_name, cat_name from catid_1 where parent_id = 1;
data:image/s3,"s3://crabby-images/02e88/02e8852d614a12476d0f4830cbe56663ca2939ae" alt=""
1.11、取出名字以"诺基亚"开头的商品
select goods_id,cat_id,goods_name,shop_price from goods where goods_name like '诺基亚%';
data:image/s3,"s3://crabby-images/b7ee0/b7ee0c884e44da77cc980e33e8d11d135fdcc6ec" alt=""
1.12、取出名字为"诺基亚Nxx"的手机
select goods_id,cat_id,goods_name,shop_price from goods where goods_name like '诺基亚N__';
data:image/s3,"s3://crabby-images/a1dc9/a1dc965b172c21e05a4bd18087f107a8649c96dd" alt=""
1.13、取出名字不以"诺基亚"开头的商品
select goods_id,cat_id,goods_name,shop_price from goods where goods_name not like '诺基亚%';
data:image/s3,"s3://crabby-images/2abf0/2abf005674545977b2d3c4cd4093a997c66ed8ea" alt=""
1.14、取出第3个栏目下面价格在1000到3000之间,并且点击量>5 "诺基亚"开头的系列商品
select goods_id,cat_id,goods_name,shop_price from goods where cat_id = 3 and (shop_price between 1000 and 3000) and goods_name like '诺基亚%';
data:image/s3,"s3://crabby-images/3ba2c/3ba2c34cc84561bb5a48b3edda7f85435f63e492" alt=""
1.15、把goods表中商品名为'诺基亚xxxx'的商品,改为'HTCxxxx',提示:大胆的把列看成变量,参与运算,甚至调用函数来处理 .(substring(),concat())
update goods set goods_name = concat('HTC',substring(goods_name,4)) where goods_name like '诺基亚%';
data:image/s3,"s3://crabby-images/696ba/696baf94c5a2dbd00ebe76245468a8fcbde87f4e" alt=""
2、分组查询group:
2.1、查出最贵的商品的价格
select max(shop_price) from goods;
data:image/s3,"s3://crabby-images/63407/63407d40f276135030fa75298ac8863dbdb5c1f8" alt=""
2.2、查出最大(最新)的商品编号
select max(goods_id) from goods;
data:image/s3,"s3://crabby-images/480a0/480a0c1edcebe21749e099613ee0052dd1d4aed5" alt=""
2.3、查出最便宜的商品的价格
select min(shop_price) from goods;
data:image/s3,"s3://crabby-images/3a12a/3a12a21862662fa727ef6db39cdc9c0a728ec159" alt=""
2.4、查出最旧(最小)的商品编号
select min(goods_id) from goods;
data:image/s3,"s3://crabby-images/bfd8f/bfd8f855c5f8a99d31a3b8960ede09e8e6a94d49" alt=""
2.5、查询该店所有商品的库存总量
select sum(goods_number) from goods;
data:image/s3,"s3://crabby-images/f81ce/f81ce488fd797c3e8de12dd3191d10a17ef590ba" alt=""
2.6、查询所有商品的平均价
select avg(shop_price) from goods;
data:image/s3,"s3://crabby-images/01f4d/01f4d834ac5eedb9e4d56e98d3ead4bc047c80b9" alt=""
2.7、查询该店一共有多少种商品
select count(*) from goods;
data:image/s3,"s3://crabby-images/755aa/755aabd455b9717b642a357f816ec4c97140a0b7" alt=""
2.8、查询每个栏目下面
最贵商品价格
最低商品价格
商品平均价格
商品库存量
商品种类
提示:(5个聚合函数,sum,avg,max,min,count与group综合运用)
select cat_id, max(shop_price),min(shop_price), avg(shop_price), sum(goods_number),count(goods_id) from goods group by cat_id;
data:image/s3,"s3://crabby-images/1f27f/1f27fcc3316bfe394f2c714e0008f1f1ea345e95" alt=""
3、having与group综合运用查询:
3.1、查询该店的商品比市场价所节省的价格
select goods_id, goods_name, market_price - shop_price as safe_money from goods;
data:image/s3,"s3://crabby-images/418b1/418b1827d5408f0806ee7eff33c6753746f41f7c" alt=""
3.2、查询每个商品所积压的货款(提示:库存*单价)
select goods_id, goods_name, goods_number * shop_price as loan from goods;
data:image/s3,"s3://crabby-images/1a3d1/1a3d1a636e9a6b9cf2fce84bad467f8aa70b4312" alt=""
3.3、查询该店积压的总货款
select sum(goods_number * shop_price) as loan_all from goods;
data:image/s3,"s3://crabby-images/d7912/d79123053d30f5c18a95d3ed5709d0c40d1abd6f" alt=""
3.4、查询该店每个栏目下面积压的货款.
select cat_id, sum(goods_number * shop_price) as loan_all from goods group by cat_id;
data:image/s3,"s3://crabby-images/e66e7/e66e7e4f8295f792afaf1cf7f6f9581da228386e" alt=""
3.5、查询比市场价省钱200元以上的商品及该商品所省的钱(where和having分别实现)
where:
select goods_id, goods_name, shop_price, market_price, market_price - shop_price as safe_money from goods where (market_price - shop_price) > 200;
having:
select goods_id, goods_name, shop_price, market_price, market_price - shop_price as safe_money from goods having safe_money > 200;
data:image/s3,"s3://crabby-images/1404f/1404f8db59445a8966968c09c3a43e873e42b484" alt=""
3.6、查询积压货款超过2W元的栏目,以及该栏目积压的货款
select cat_id, sum(goods_number * shop_price) as loan_all from goods group by cat_id having loan_all > 20000;
data:image/s3,"s3://crabby-images/50e81/50e81c1bc8805762ef6e77c9ab604e20e634c70e" alt=""
3.7、where-having-group综合练习题
data:image/s3,"s3://crabby-images/37955/37955eab6d48b273df41024e3710a8455b1ff188" alt=""
要求:查询出2门及2门以上不及格者的平均成绩。
select name, avg(score) as avg_score, sum(score < 60) as fail_courses from result
group by name
having fail_courses >= 2;
data:image/s3,"s3://crabby-images/e407b/e407b61bc47e5afc8096d6496c43db30b0777ca5" alt=""
Ps:这里很容易出错,一开始我自己就错用count( )来统计不及格成绩数,但是count( )只能计算行数,及格数也占一行,所以统计出来的数量是错误的。另外,sql思路与以往有所区别,要什么就先取什么,然后再一步步筛选。
网友评论