现在有张表products是产品表,vend_id是供应商id,prod_price是供应价格,现在需要统计每个供应商供应了多少商品,供应商品的平均价格,sql如下:
SELECT vend_id, AVG( prod_price ), COUNT( * ) AS num_prods FROM products GROUP BY vend_id
输出结果如下:
vend_id AVG(prod_price) num_prods 1001 10.323333 3 1002 6.205000 2 1003 13.212857 7 1005 45.000000 2
然后我们还想统计平均值总和、汇总商品数,sql如下:
SELECT vend_id, AVG( prod_price ), COUNT( * ) AS num_prods FROM products GROUP BY vend_id WITH ROLLUP
多增加一个WITH ROLLUP即可实现汇总字段,结果如下:
vend_id AVG( prod_price ) num_prods 1001 10.323333 3 1002 6.205000 2 1003 13.212857 7 1005 45.000000 2 16.133571 14
where与having非常类似.都能筛选数据.表达式完全一致. 但是职责的确不同.where负责对表中的字段进行筛选,having负责对where筛选后的结果集再次筛选。这也就是where不能使用别名字段来筛选的原因,因为数据中没有这个字段。&n...
例如我们需要查询商品表中每个分类中商品id最大的记录,并且显示商品价格以下是表结构:id catename title &nb...
由于在开发中不小心删除客户上传的商品数据,客户本身也不好说话,只好恢复数据库,记录下过程。原理是数据库开启bin-log功能,然后再通过备份的bin-log进行数据库恢复。先查找备份的数据库日志二进制文件。一般在mysql的data文件夹中,文件名大概为mysql-bin.00001,具体看文件的修...
(1).首先我们需要了解limit分页的工作流程demo: SELECT * FROM table LIMIT 10000,5 通常我们会认为以上SQL会从10000条后面取5条,正确的是取出10005条,然后再抛弃前...
项目和第三方系统对接,由于第三方开发人员属于兼职,数据库结构不一致的问题只能我来处理。此处文章用本地模拟演示。数据库资料:1号服务器: 账号root 密码root IP:127.0.0.1 数据库名称:data1 2号服务器...
项目中查询数据部分字段出现null,影响到了排序,但是由于没有数据库权限,还想将null转为其他值表示;例如现有表member的原始数据:SELECT * FROM memberid &n...