10-4 6-4 查询厂商“D“生产的PC和便携式电脑的平均价格 (10 分)思路+详解+测试用例

前言:测试用表

贴心杰将这个测试表分享给大家 ,如果大家做题的时候发现那个点过不去,一定不要直接看别人的博客,先自己测试用例,如果思路也对 ,验证数据也对,还有错误 你再看看别人的思路!!!

CREATE TABLE product
( maker CHAR(20) ,          -- 制造商model CHAR(20) NOT NULL,  -- 产品型号TYPE CHAR(20),            -- 产品类型PRIMARY KEY(model)
);
CREATE TABLE pc
( model CHAR(20) NOT NULL,    -- 型号speed  DECIMAL(6,2),        -- 速度ram  INT,                   -- 内存hd DECIMAL(6,2),            -- 硬盘容量cd CHAR(4),                 -- 光驱price INT,                  -- 价钱PRIMARY KEY(model),FOREIGN KEY(model) REFERENCES product(model)
);
CREATE TABLE laptop
( model CHAR(20) NOT NULL,    -- 型号speed  DECIMAL(6,2),        -- 速度 ram  INT,                   -- 内存hd DECIMAL(6,2),            -- 硬盘容量screen DECIMAL(6,2),        -- 屏幕大小price INT,                  -- 价钱PRIMARY KEY(model),FOREIGN KEY(model) REFERENCES product(model) 
);INSERT INTO productVALUES('D','2001','便携式电脑'),('D','2002','便携式电脑'),('D','3001','打印机'),('D','1008','个人电脑'),('D','1009','个人电脑');INSERT INTO productVALUES('A',1001,'个人电脑'),('A',1002,'个人电脑');INSERT INTO pcVALUES('1008',180.00,32,2.00,'8X',3699),('1009',200.00,32,2.50,'8X',2599);INSERT INTO pcVALUES('1001'	,133.00,	16,	1.60,	'6X',	1595),('1002',	120.00,	16	,1.60,	'6X',	1399);INSERT INTO laptopVALUES('2001',100.00,20,1.10,9.50,1999),(2002,117.00,12,0.75,11.30,2499);

一:10-4 6-4 查询厂商"D"生产的PC和便携式电脑的平均价格 (10 分)

-- 查询厂商D生产的PC和便携式电脑的平均价格-- 分析:1.查询出D和PC一个表 字段为price
--      2.查询D和laptop一个表 字段为price
--     3.union all 两个表 然后求出平均值和 注意 union all 是不去重的  union 是去重的
--     4.还有就是这道题最后求取的结果是要四舍五入的  要用 round(平均值) 别问我怎么知道的,我是试出来的 先用的floor 不对
--       然后改成 round 就对了
--    -- 1.
-- select price
--     from product,pc
--     where product.model = pc.model;-- -- 2.
-- select price
--     from product,laptop
--     where product.model = laptop.model;-- 3.
SELECT round(AVG(price)) AS avg_priceFROM (SELECT priceFROM product,pcWHERE product.model = pc.modelAND maker = 'D'UNION ALLSELECT priceFROM product,laptopWHERE product.model = laptop.model   AND maker = 'D') temp;

二:10-3 6-3 查询厂商"A"生产的PC的平均价格 (10 分)

-- 查询厂商A生产的PC的平均价格。-- 分析:1.查询出A生产的PC
--      2.求其平均价格select avg(price) as avg_pricefrom product,pcwhere product.model = pc.modeland maker = 'A';

三:10-6 6-6 查询各厂商生产的便携式电脑的显示器平均尺寸 (10 分)

--  查询各厂商生产的便携式电脑的显示器平均尺寸。
--  分析:1.先求出各个厂商对应的电脑屏幕
--       2.将其作为子表进行分组查询 平均尺寸;-- 错误示例:聚合函数不能和字段一块用  当 不是group by 的时候
-- select maker,avg(screen) as avg_screen
--     from product,laptop
--     where product.model = laptop.model;-- -- 1.
-- select maker,screen
--     from product,laptop
--     where product.model = laptop.model;-- 2.
select maker,avg(screen) as avg_screenfrom (select maker,screenfrom product,laptopwhere product.model = laptop.model) tempgroup by maker;

四:10-7 6-7 查询生产三种不同型号的PC的厂商 (10 分)

-- 查询生产三种不同型号的PC的厂商。
-- 分析:1.先将pc表和product表联合起来 字段为厂商 和 型号 这样求出 每个厂商对应的pc型号  表1
--      2.对表1进行分组查询 字段为 厂商 和 型号个数 并筛选出数量为3的厂商  表2
--      3.对表2进行查询 -- -- 1.
-- select maker,pc.model
--     from pc,product
--     where pc.model = product.model-- -- 2
-- select maker,count(maker) as nums
--     from (select maker,pc.model
--                 from pc,product
--                 where pc.model = product.model) temp
--      group by maker  having nums = 3;     -- -- 3select makerfrom (select maker,count(maker) as numsfrom (select maker,pc.modelfrom pc,productwhere pc.model = product.model) tempgroup by maker having nums = 3) temp1         

五:10-10 6-10 查询所有生产打印机的厂商生产的PC的硬盘平均容量 (10 分)

-- 查询所有生产打印机的厂商生产的PC的硬盘平均容量。-- 分析:
--     1.查询出既生产 打印机 又生产 PC 的厂商    
--       1>.查询出生产打印机的厂商 表1
--       2>.查询product表 字段为 厂商,model,条件为 maker 来自 表1 and type = 个人电脑 表2
--    2.联合表2和PC表求出 平均硬盘容量-- 1.1
-- select maker
--     from product,printer
--     where product.model = printer.model-- -- 1.2
-- select maker,product.model
--     from product
--     where maker in (select maker
--                         from product,printer
--                         where product.model = printer.model)
--     and type = "个人电脑"-- 2
select avg(hd) as avg_hdfrom pc,(select maker,product.modelfrom productwhere maker in (select makerfrom product,printerwhere product.model = printer.model)and type = "个人电脑") tempwhere pc.model = temp.model;                

其他 有疑问的题可以留言 , 上方分享一下我认为很好的题!!!!!!!!!
写sql语句 一定要有自己的分析,然后一步步写写,最重要的你的逻辑表达出来,这几道破题,不是最重要的
好了 有疑问的题可以留言 或择你认为有难度的题也可以分享给我 ,我非常乐意做题,加油陌生人

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/308179.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何校验内存数据的一致性,DynamicExpresso 算是帮上大忙了

一:背景1. 讲故事记的在上一家公司做全内存项目的时候,因为一些关键表会在程序 startup 的时候全量灌入到内存中,但随着时间的推移,内存和数据库的同步偶尔会出现数据差异的情况,伴随着就是运营那边报过来的 bug&#…

qt 实现html 编辑器,基于QT的HTML编辑器的设计与实现.doc

PAGEPAGE 1郑州大学毕业设计(论文)题 目:基于Qt的html编辑器的设计与实现指导教师: 职称:学生姓名: 学号:专 业:院(系):完成时间: 2012年5月10日2012年5月10日目录TOC \o "1-2&…

临界表储存图的数据(思路+详解+图示)

一:前言 当我们考虑用邻接表储存数据的时候,一定会拿邻接矩阵和其进行比较。邻接矩阵在储存数量较小的数据是耗费的内存是要高于邻接表的。那么我们在做题的时候如果出现内存超限,那就要注意了,可以考虑换用邻接表来储存数据了 …

译 | 在 Azure SQL 上节约成本的八种方法

点击上方关注“汪宇杰博客”原文:John JG Chirapurath翻译:汪宇杰导语当今世界,企业正崭露头角,渴望重整与重建,但仍处于不确定的时期。节约成本并将开支重新分配到最重要的位置与以往一样重要,许多公司将云…

7-2 单源最短路径 (10 分)(思路+详解+邻接表做法)Come Brather!!!!!!!!!!

一:前言 本次题解先展示用邻接矩阵做的,但其会出现内存超限,因为确实是临界矩阵在数据很大的时候相比临界表是耗内存的,但是以前习惯用临界矩阵了,所以一上来就用临界矩阵做了,后来上网查了后知道邻接矩阵…

计算机一级办公软件试题,计算机一级《MS Office》练习题(含答案)

计算机一级《MS Office》练习题(含答案)11.完整的计算机软件指的是__________.A.程序、数据与相应的文档B.系统软件与应用软件C.操作系统与应用软件D.操作系统和办公软件12.在微机的配置中常看到“P42.4G”字样,其中数字“2.4G”表示__________.A.处理器的时钟频率是2.4GHzB.处…

在.NET Core中使用MongoDB明细教程(3):Skip, Sort, Limit, Projections

到目前为止,我们已经讨论了创建文档, 检索文档,现在让我们来研究一下文档排序,指定要跳过或限制返回的文档数量,以及如何进行投影。此篇文章中的实例代码摘录自原文,未像前几篇文章一样进行实际代码的验证。作者&#…

map容器的使用 逆序遍历map容器当中的数据

一&#xff1a;前言 这个逆序遍历是将map容器的迭代器进行了变化&#xff0c;reverse_iterator逆向遍历的迭代器 &#xff0c;它需要 rbegin()和rend()方法指出反向遍历的 起始位置和终止位置。 二&#xff1a;上码演示 #include<bits/stdc.h> using namespace std;in…

计算机检测维修与数据恢复课件,2017年全国职业院校技能大赛中职组“计算机检测维修与数据恢复”赛项说明会ppt课件.ppt...

《2017年全国职业院校技能大赛中职组“计算机检测维修与数据恢复”赛项说明会ppt课件.ppt》由会员分享&#xff0c;可在线阅读&#xff0c;更多相关《2017年全国职业院校技能大赛中职组“计算机检测维修与数据恢复”赛项说明会ppt课件.ppt(23页珍藏版)》请在人人文库网上搜索。…

递归优化的这三种方式你知道吗?

估计找工作的&#xff0c;都会碰到面试官老是问道“递归算法”&#xff0c;感同身受&#xff0c;前段时间面试的时候&#xff0c;就有一家问道这个问题&#xff0c;是非常典型的问题。在前面一篇世界上有哪些代码量很少&#xff0c;但很牛逼很经典的算法或项目案例&#xff1f;…

7-7 硬币找钱问题 (10 分)(思路+详解+double类型数据的处理)Come baby!!!!!!!!!!!!!!!!!!!!

一&#xff1a;题目 设有6 种不同面值的硬币&#xff0c;各硬币的面值分别为5 分&#xff0c;1 角&#xff0c;2 角&#xff0c;5 角&#xff0c;1 元&#xff0c;2元。现要用这些面值的硬币来购物。在购物中希望使用最少个数硬币。例如&#xff0c;1 次购物需要付款0.55 元&a…

7-6 区间覆盖 (10 分)(思路+详解)Come 宝!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

一&#xff1a;题目 设 x 1 ​ ,x 2 ​ ,…,x n ​ 是实直线上的n个点。用固定长度的闭区间覆盖这n个点&#xff0c;至少需要多少个这样的固定长度闭区间&#xff1f; 输入格式: 第1行有2个正整数n(n<50)和k&#xff0c;表示有n个点&#xff0c;且固定长度闭区间的长度为k…

你有 GitHub 帐号么?平时都用它来干什么?

这是头哥侃码的第212篇原创上个月&#xff0c;我写了一篇 #与抑郁症斗争的那些年&#xff0c;我也曾想去死一死#&#xff0c;分享了自己在创业失败那段时间的抑郁焦虑的经历。很显然&#xff0c;这已经不是我第一次把自己的悲惨经历写出来了。在文章推送后&#xff0c;有读者在…

xml可以html标签吗,自定义html标签(XML)

HTML和HTML5都可以自定义标签。在浏览一些网站的源代码后&#xff0c;你会发现一些网页中存在你不认识的标签和元素&#xff0c;但是这些元素却能被浏览器执行。这就是自定义元素。自由定义标签而不必使用预定义好的语义标签之后&#xff0c;更能语义化我们的内容。在HTML5之前…

7-5 汽车加油问题 (20 分)(思路+详解)Come 宝!!!!!!!!!!!!!

一&#xff1a;题目 题目来源&#xff1a;王晓东《算法设计与分析》 一辆汽车加满油后可行驶 n公里。旅途中有若干个加油站。设计一个有效算法&#xff0c;指出应 在哪些加油站停靠加油&#xff0c;使沿途加油次数最少。 输入格式: 第一行有 2 个正整数n和 k&#xff08;k&l…

在生产环境下处理EFCore数据库迁移的五种方法

在生产环境下处理EFCore数据库迁移的五种方法原文链接&#xff1a;https://www.thereformedprogrammer.net/handling-entity-framework-core-database-migrations-in-production-part-1/作者:Jon P Smith&#xff0c;是《 Entity Framework Core in Action》的作者安德鲁洛克&a…

计算机系统结构答案汤志忠,计算机系统结构(第2版)郑伟明汤志忠课后习题答案以及例题收录.doc...

计算机系统结构(第2版)郑伟明汤志忠课后习题答案以及例题收录.doc 1计算机系统结构第2版郑伟明汤志忠编著清华大学出版社习题解答21目录11第一章P331719(透明性概念)&#xff0c;112118(AMDAHL定律)&#xff0c;119、121、124(CPI/MIPS)12第二章P12423、25、26(浮点数性能)&…

7-1 活动选择问题 (25 分)(思路+详解+扩展)宝 今天你AC了吗!!!

一&#xff1a;题目 假定一个有n个活动(activity)的集合S{a 1 ​ ,a 2 ​ ,…,a n ​ }&#xff0c;这些活动使用同一个资源&#xff08;例如同一个阶梯教室&#xff09;&#xff0c;而这个资源在某个时刻只能供一个活动使用。每个活动a i ​ 都有一个开始时间s i ​ 和一个结…

初识ABP vNext(5):ABP扩展实体

点击上方蓝字"小黑在哪里"关注我吧扩展实体路由整理前言上一篇实现了前端vue部分的用户登录和菜单权限控制&#xff0c;但是有一些问题需要解决&#xff0c;比如用户头像、用户介绍字段目前还没有&#xff0c;下面就来完善一下。开始因为用户实体是ABP模板自动生成的…

计算机管理-磁盘管理中进行扩展卷操作,管理磁盘diskpart命令

很多时候&#xff0c;我们需要对磁盘进行诸如创建分区、转换分区表格式、格式化、扩展卷等操作&#xff0c;尤其你在一台安装了全新的硬盘的电脑上安装windows的时候&#xff0c;磁盘管理操作显得更加必要。通常&#xff0c;人们会使用第三方Windows PE启动盘当中附带的可视化磁…