以下题目用到工程供应数据库关系模式:
供应商(供应商号,供应商名,城市)
        S(Sno,Sname,City)
零件(零件号,零件名,零件颜色)
     P(Pno,Pname,Color)
工程(工程号,工程名 )
     J(Jno,Jname)
供应(供应商号,零件号,工程号,供应数量)
     SPJ(Sno,Pno,Jno,Qty)

1. 求供应工程号‘J1’零件的供应商名SNAME。(用IN 子查询)
   结果应该是S-A

SELECT SNAME
FROM S
WHERE SNO IN
(
SELECT SNO
FROM SPJ
WHERE JNO='J1'
)

2. 求供应工程号‘J1’零件的供应商名SNAME。(用连接,  查询结果要消除重复)
   结果应该是S-A

SELECT DISTINCT SNAME
FROM S,SPJ
WHERE S.SNO=SPJ.SNO AND JNO='J1'

3. 求供应工程号‘J1’零件的供应商名SNAME。(EXISTS子查询)
   结果应该是S-A

SELECT SNAME
FROM S
WHERE EXISTS
(
SELECT *
FROM SPJ
WHERE S.SNO=SPJ.SNO AND JNO='J1'
)

4求没有供应过零件的供应商名。(NOT IN)
   结果应是S-C, S-D

SELECT SNAME
FROM S
WHERE SNO NOT IN
(
SELECT SNO
FROM SPJ
WHERE QTY!=0
)

5求没有供应过零件的供应商名。(NOT EXISTS)
   结果应是S-C, S-D

SELECT SNAME
FROM S
WHERE NOT EXISTS
(
SELECT *
FROM SPJ
WHERE S.SNO=SPJ.SNO AND QTY!=0
)

6. 求使用所有零件的工程名JNAME。
  (查询工程中的工程名, 条件是不存在这样的零件, 该工程不用)
结果应该是J-A

SELECT JNAME
FROM J
WHERE NOT EXISTS
(
SELECT *
FROM P
WHERE NOT EXISTS
(
SELECT *
FROM SPJ
WHERE JNO=J.JNO AND PNO=P.PNO
) )

7.求至少用了 工程号‘J2’ 工程所使用所有零件的工程名JNAME。
   (从J中查询JNAME, 条件是不存在这样的零件:  J2使用并且该工程不用)

结果应该是J-A, J-B

SELECT JNAME
FROM J
WHERE NOT EXISTS
(
SELECT *
FROM P
WHERE EXISTS
(
SELECT *
FROM SPJ
WHERE JNO='J2' AND PNO=P.PNO
)
AND
NOT EXISTS
(
SELECT *
FROM SPJ
WHERE JNO=J.JNO AND PNO=P.PNO
)
)

8. 求供应了供应商号为‘S2’所供应所有零件的供应商名SNAME
(查询供应商名,条件是不存在这样的零件:  S2供应并且该供应商不供应)

SELECT SNAME
FROM S
WHERE NOT EXISTS
( SELECT *
FROM P
WHERE EXISTS(
SELECT *
FROM SPJ
WHERE SPJ.SNO='S2'
AND SPJ.PNO=P.PNO
)
AND NOT EXISTS(
SELECT *
FROM SPJ
WHERE SPJ.SNO=S.SNO
AND SPJ.PNO=P.PNO
)
)

9. 查询供应了所有工程的供应商名。
(查询供应商名,条件是不存在这样的工程, 该供应商不供应)

SELECT SNAME
FROM S
WHERE NOT EXISTS
(
SELECT *
FROM J
WHERE NOT EXISTS
(
SELECT *
FROM SPJ
WHERE S.SNO=SNO
AND J.JNO=JNO
)
)

10.    查询没有使用北京供应商供应的’红’色零件的工程名(NOT IN)
结果应该是J-A, J-B,J-C

SELECT JNAME
FROM J
WHERE JNO NOT IN
(
SELECT JNO
FROM SPJ,S,P
WHERE SPJ.SNO=S.SNO AND SPJ.PNO=P.PNO
AND CITY='北京' AND COLOR ='红'
)

11. 查询供应商号,供应商名,工程号,零件号,数量。包括未供应过零件的供应商。

SELECT S.SNO,SNAME,SPJ.JNO,SPJ.PNO,QTY
FROM S,SPJ
WHERE S.SNO *=SPJ.SNO

12 查询供应过颜色为’黑’的零件的供应商名

SELECT SNAME
FROM S,P,SPJ
WHERE S.SNO =SPJ.SNO AND P.PNO=SPJ.PNO AND COLOR='黑'

13查询供应商号,工程号, 供应零件数量合计

SELECT SNO,JNO,sum(QTY)
FROM SPJ
GROUP BY SNO,JNO

额,下面截图中的查询语句写错了。

14,查询工程号,工程名,供应的次数,供应的零件数量合计

SELECT J.JNO,JNAME,COUNT(*),SUM(QTY)
FROM J,SPJ
WHERE J.JNO=SPJ.JNO
GROUP BY J.JNO,JNAME

因为要统计供应次数,要按照供应的对象工程号和工程名来分组。

15查询与供应商名‘S-C’同城市的供应商名

SELECT SNAME
FROM S
WHERE CITY=
(
SELECT CITY
FROM S
WHERE SNAME='S-C'
)

16查询供应过>=3次的供应商名

SELECT SNAME
FROM S
WHERE SNO IN
(
SELECT SNO
FROM SPJ
GROUP BY SNO
HAVING COUNT(*)>=3
)

17. 查询供应次数大于S2供应次数的供应商号

SELECT SNO
FROM SPJ
GROUP BY SNO
HAVING COUNT(*)>
(
SELECT COUNT(*)
FROM SPJ
WHERE SNO='S2'
)

18查询供应给工程号’J2’ 零件数>=10的供应商名

SELECT SNAME
FROM S
WHERE SNO IN
(
SELECT SNO
FROM SPJ
WHERE JNO='J2'
GROUP BY SNO
HAVING SUM(QTY)>=10
)

数据库——SQL-SERVER练习(5) 供应关系的更多相关文章

  1. 数据库SQL Server与C#中数据类型的对应关系

    ylbtech- .NET-Basic:数据库SQL Server与C#中数据类型的对应关系 数据库SQL SServer与C#中数据类型的对应关系 1.A,返回顶部 数据库 C#程序 int int ...

  2. 数据库管理工具神器-DataGrip,可同时管理多个主流数据库[SQL Server,MySQL,Oracle等]连接

    前言 DataGrip:Jet Brains出品的一款数据库管理工具(没错,是Jet Brains出品,必属精品).DataGrip整合集成了当前主流数据库(如:SQL Server, MySQL, ...

  3. sql server ------创建本地数据库 SQL Server 排序规则

    sql server完整复制数据库 sql server导入导出方法 SQL Server 排序规则

  4. 数据库 SQL Server 到 MySQL 迁移方法总结

    最近接手一起老项目数据库 SQL Server 到 MySQL 的迁移.因此迁移前进行了一些调查和总结.下面是一些 SQL Server 到 MySQL 的迁移方法. 1. 使用 SQLyog 迁移 ...

  5. [数据库]SQL Server 用户NT AUTHORITY\IUSR 登录失败

    今天打开网站时,突然报这个错误,平时都好好的 Cannot open database "JMECC" requested by the login. The login fail ...

  6. 数据库SQL Server DAC 导入导出数据到SQL Azure问题

    对Export data-tier application报错的处理 Error:SQL71564 这个问题是数据库中一些对象如MS_Description,MS_DiagramPane1不支持DAC ...

  7. 如何分离数据库 (SQL Server Management Studio)

    在 SQL Server Management Studio 对象资源管理器中,连接到 SQL Server 数据库引擎的实例上,再展开该实例. 展开“数据库”,并选择要分离的用户数据库的名称. 分离 ...

  8. 批量还原数据库 SQL Server 2008

    1.如果你够懒,不想一步一步点路径,一步一步选择 2.如果你连单个备份数据库的存储过程都不想多执行,一般每还原一个需要修改数据库名 下面的脚本适合你: /*********************** ...

  9. 基础知识(C#语法、数据库SQL Server)回顾与总结

    前言 已经有大概一个多月没有更新博客,可能是开始变得有点懒散了吧,有时候想写,但是又需要额外投入更多的时间去学习,感觉精力完全不够用啊,所以为了弥补这一个多月的潜水,决定写一篇,衔接9月未写博客的空缺 ...

  10. 数据库 --> SQL Server 和 Oracle 以及 MySQL 区别

    SQL Server 和 Oracle 以及 MySQL 区别 三者是目前市场占有率最高(依安装量而非收入)的关系数据库,而且很有代表性.排行第四的DB2(属IBM公司),与Oracle的定位和架构非 ...

随机推荐

  1. OOAD 面向对象的分析与设计

      OOAD  面向对象的分析与设计            OOA-----分析阶段(针对业务问题清晰视图, 列出系统完成任务,  整理业务的公共词汇,  列出解决业务的解决方法)         O ...

  2. [C]副作用和序列点

    概述 副作用: <C语言核心技术>对副作用的描述: 表达式内包含了一串的常量.标识符.运算符(指示的运算方式).表达式的目的可以是获得结果值,或者得到运算的副作用(side effect) ...

  3. Java之Calendar类

    Calendar类概述 java.util.Calendar 是日历类,在Date后出现,替换掉了许多Date的方法.该类将所有可能用到的时间信息封装为静态成员变量,方便获取.日历类就是方便获取各个时 ...

  4. python之字符串的拼接总结

    加号连接 1.通过+号连接起来 逗号连接 2.通过都好连接起来 但是,这里值得注意的是,只能用于print打印,赋值组操作会生成元组 直接连接 3.直接连接中间有无空格均可 %连接 在python2. ...

  5. 5种智能指针指向数组的方法| 5 methods for c++ shared_ptr point to an array

    本文首发于个人博客https://kezunlin.me/post/b82753fc/,欢迎阅读最新内容! 5 methods for c++ shared_ptr point to an array ...

  6. Add an Action that Displays a Pop-up Window 添加显示弹出窗口按钮

    In this lesson, you will learn how to create an Action that shows a pop-up window. This type of Acti ...

  7. mysql 5.7版本安装

    1.下载tar包,这里使用wget从官网下载 wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.22-linux-glibc2. ...

  8. Android项目模块化/组件化开发(非原创)

    文章大纲 一.项目模块化初步介绍二.项目模块化的两种模式与比较三.大型项目模块化的演进四.项目模块化总结五.参考文章   一.项目模块化初步介绍 1. 前言 在Android开发中,随着项目的不断扩展 ...

  9. CentOS7 安装frp与开机启动

    1. 下载frp程序文件 https://github.com/fatedier/frp/releases 2. 解压文件 下载后解压到自己的目录,我这里解压到/usr/local/frp: 3. 添 ...

  10. RHEL 6.6配置网易CentOS镜像的yum源小结

       之前没有使用过网易CentOS镜像的yum源,最近由于需要,遂在一台测试服务器验证.测试了一下如何配置使用网易的Cent0S的yum源.此文仅仅是笔记性质,参考了网上大量资料(文末"参 ...