1 注意

select cout(*) from 表名; 查询的就是绝对的行数,哪怕某一列所有字段全部为NULL,也计算在内。而select cout(列名) form 表名;查询的是该列不为null的所有行的行数。

用count(*)和count(1)那个更好?

对于myisam引擎的表,没有区别,这种引擎内部有一个计数器在维护着行数,对Innodb的表,用count(*)直接读行数,效率很低,因为Innodb的表真的要去数一遍。

2

mysql> select sum(shop_price) from
-> goods
-> where cat_id = 3;
mysql> select sum(goods_number) from goods
-> where cat_id = 4;

计算每个栏目下的库存量之和

配合group语句使用

mysql> select cat_id, sum(goods_number) from goods
-> group by cat_id;

典型错误

mysql> select goos_id,sum(goods_number) from goods;
ERROR 1140 (42000): In aggregated query without GROUP BY, expression #1 of SELECT list contains nonaggregated column 'test_db.goods.goos_id'; this is incompatible with sql_mode=only_full_group_by

运算不对应,没办法取出goos_id(MySQL 8.0.13 这条语句不会执行)。

3

按照cat_id分组,计算每个栏目下的商品的平均价格

mysql> select cat_id,avg(shop_price) from goods
-> group by cat_id;

这里cat_id已经按组分类,所有语义上没有问题。

严格讲,以group by a, b,c为列,则select的列,只能在a,b,c中选择。

4

查询本店价格比市场价省的钱,并且要求省钱200元以上取出来

mysql> select goos_id,goods_name,(shop_price-market_price) as discount from goods
-> where
-> (shop_price - market_price) > 200;

mysql> select goos_id,goods_name,(shop_price-market_price) as discount from goods
-> having discount;

这是典型错误

mysql> select goos_id,goods_name,(shop_price-market_price) as discount from goods
-> where
-> discount > 200;
ERROR 1054 (42S22): Unknown column 'discount' in 'where clause'

这种写法也可以(P20)

mysql> select goos_id,goods_name,(shop_price-market_price) as discount from goods
-> where 1
-> having discount > 200;

5

查询每个商品所积压的货款

mysql> select goos_id,goods_number * shop_price from goods;

6

查询每个商品的积压货款之和

mysql> select sum(goods_number * shop_price) from goods;

7

查询每个栏目下,积压的货款(需要用到分组)

mysql> select cat_id,sum(shop_price * goods_number) from goods
-> group by cat_id;

8

查询积压货款超过2W元的栏目,以及该栏目积压的货款

mysql> select cat_id,sum(goods_number * shop_price) as k from goods
-> group by cat_id
-> having k > 20000;

对结果集操作,就需要用到having

错误做法

mysql> select cat_id, sum(goods_number * shop_price) from goods
-> where
-> (goods_number * shop_price) >20000
-> group by cat_id;

9

查询本店价比市场价省的钱,且筛选出省钱200以上的商品,用where和having分别来实现

mysql> select goos_id,goods_name,(shop_price - market_price) as discount from goods
-> having
-> discount > 200;

mysql> select goos_id,goods_name,shop_price - market_price from goods
-> where
-> (shop_price - market_price) > 200;

10

where-having-group综合练习

创建一张表

mysql> create table result
-> (
-> name varchar(10),
-> subject varchar(10),
-> score tinyint unsigned
-> )engine myisam charset utf8;

插入数据

mysql> insert into result
-> values
-> ('张三','数学',90),
-> ('张三','语文',50),
-> ('张三','地理',40),
-> ('李四','语文',55),
-> ('李四','政治',45),
-> ('王五','政治',30);
Query OK, 6 rows affected (0.40 sec)

要求:查询出2门及2门以上不及格者的平均成绩

如张三 (90+50+40)/3 = 60

李四 (55+45) / 2 = 50;

注意count(1)或者count(0)查找出来的都是当前表的列数

1 第一步就是查找所有人的平均分

mysql> select name,avg(score) from result
-> group by name;

2 再想办法计算出每个人的挂科的情况

mysql> select name,subject,score,score < 60 as ungrade from result;

3

如上,挂科数就是ungrade的和

mysql> select name,avg(score),sum(score < 60 ) as ungread
-> from result
-> group by name;

4 已经出现结果集,再对结果集进行一次操作

mysql> select name,avg(score),sum(score < 60 ) as ungread
-> from result
-> group by name
-> having ungread >= 2;

这一个思路是逆向思维,先查出所有人的平均,再筛选,如果正常的考虑,我们会这样做,先找出谁的挂科数>2,找到这些人,再求这些人的平均分。

MySQL学习(六)的更多相关文章

  1. MySQL学习(六)——自定义连接池

    1.连接池概念 用池来管理Connection,这样可以重复使用Connection.有了池,我们就不用自己来创建Connection,而是通过池来获取Connection对象.当使用完Connect ...

  2. MySql学习(六) —— 数据库优化理论(二) —— 查询优化技术

    逻辑查询优化包括的技术 1)子查询优化  2)视图重写  3)等价谓词重写  4)条件简化  5)外连接消除  6)嵌套连接消除  7)连接消除  8)语义优化 9)非SPJ优化 一.子查询优化 1. ...

  3. mysql存储引擎(mysql学习六)

    存储引擎 现在只有InnoDB支持外键 上接着学习笔记五 class表中有外键,所以不能修改存储引擎 表类型   默认的服务器表类型,通过my.ini可以配置    Default-storage-e ...

  4. 我的MYSQL学习心得(六) 函数

    我的MYSQL学习心得(六) 函数 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据类 ...

  5. 我的MYSQL学习心得(十六) 优化

    我的MYSQL学习心得(十六) 优化 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据 ...

  6. 我的MYSQL学习心得(六)

    原文:我的MYSQL学习心得(六) 我的MYSQL学习心得(六) 我的MYSQL学习心得(一) 我的MYSQL学习心得(二) 我的MYSQL学习心得(三) 我的MYSQL学习心得(四) 我的MYSQL ...

  7. 我的MYSQL学习心得(一) 简单语法

    我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据类型 我的MYSQL学习心得(五) 运 ...

  8. 我的MYSQL学习心得(二) 数据类型宽度

    我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据类型 我的MYSQL学习心得(五) 运 ...

  9. 我的MYSQL学习心得(三) 查看字段长度

    我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(四) 数据类型 我的MYSQL学习心得(五) 运 ...

随机推荐

  1. JVM的垃圾回收机制

    JVM的垃圾回收机制:(GC通过确定对象是否被活动对象引用来确定是否收集该对象.) 1.触发GC(Garbage Collector)的条件. (1.GC在优先级最低的线程中运行,在未运行的线程中进行 ...

  2. sed/awk advance

    $ echo test.file [Group1]cacheways = 19 [Group2]cacheways = 19 $ ls test.sh FILE=test.file2 # Set Gr ...

  3. 谈论linux同组多用户操作问题

    同组多用户,最先起到什么作用这个我也是不明白的, 然后乱搞了一堆, 下面我做个笔记帮组日后分析. 一个用户组承载多个用户, 像这样 这是我原先的思路.然后就是chenglee用户和chenglee12 ...

  4. [BeiJing wc2012]冻结 题解

    HYSBZ - 2662 这个题如果我们先想用平常的方法来建图,因为我们无法确定是否使用卡片,如果我们每个点每个边都建图,那么非常耗时占空间:注意到k是比较小的,所以我们可以把k拆开,把一个点分为k个 ...

  5. 【TensorFlow】tf.nn.max_pool实现池化操作

    max pooling是CNN当中的最大值池化操作,其实用法和卷积很类似 有些地方可以从卷积去参考[TensorFlow]tf.nn.conv2d是怎样实现卷积的? tf.nn.max_pool(va ...

  6. MFC限制edit控件的字符输入长度

    一. 1.Edit 控件添加EN_CHANGE事件 #define MAX_SIZE 200 void CMyDlg::OnChangeEditFeed() { // TODO: 如果该控件是 RIC ...

  7. JS实现复制页面文字弹出消息提醒

    先上效果图: 简洁版: <script type="text/javascript"> document.body.oncopy=function(){ alert(& ...

  8. Spring Security原理与应用

    Spring Security是什么 Spring Security是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架.它提供了一组可以在Spring应用上下文中配置 ...

  9. [转] Java 基础

    1. 面向对象和面向过程的区别 面向过程 面向对象 2. Java 语言有哪些特点 3. 关于 JVM JDK 和 JRE 最详细通俗的解答 JVM JDK 和 JRE 4. Oracle JDK 和 ...

  10. Sql Ado.net 学习笔记之连接字符串

    https://www.cnblogs.com/heng95/p/5902019.html 连接字符串 SQL Client .net数据提供程序在连接到数据库时极其灵活,它提供了多种用以生成连接字符 ...