ORACLE 实验二

实验二:数据操纵

实验学时:4学时

实验类型:综合型

实验要求:必修

一、实验目的

1、掌握SQL数据查询语句;

2、掌握SQL聚集函数的使用。

3、掌握SQL插入、改动、删除语句的使用。

二、实验内容

1.project项目採购数据库,在实验3.2的基础上插入例子数据并完毕下列操作:

(1)    
求向projectJ1提供零件的供应商的编号。

(2)    
求向projectJ1提供零件P1的供应商的编号。

(3)    
求向projectJ1提供红色零件的供应商的编号。

(4)    
求没有使用天津供应商提供的红色零件的project号。

(5)    
求至少使用了供应商S1所提供的所有零件的project号。

(6)    
统计各个供应商供应的零件总数。

(7)    
求至少使用了3种以上零件的project号。

(8)    
把全部红色零件的颜色改为粉红色。

(9)    
将向projectJ1提供零件P1的供应商S1改为S2提供。

(10)
删除所有红色零件以及对应的供应-使用记录。

2.产品价格数据库。在实验3.3的基础上插入例子数据并完毕下列操作

(1)    
列出速度至少是150的那些PC机的型号。

(2)    
哪些厂家生产的LAPTOP配置的硬盘不低于1。

(3)    
找出由生产厂B所生产的所有产品的型号和价格。

(4)    
找出全部的彩色激光打印机的型号。

(5)    
找出生产执行速度至少是450MC的PC的厂商。

(6)    
找出价格最高的打印机。

(7)    
找出每个生产厂商的PC机的最高价格。

(8)    
找出至少生产三种不同型号PC机的厂商。

(9)    
厂商A兼并厂商B。把全部B厂商生产的产品改成由厂商A生产。

(10)
删除全部不生产打印机的厂商生产的LAPTOP机。

三、实验原理、方法和手段

在实验3定义的关系模式的基础上。使用SQL数据操作语句完毕数据的查询和更新操作。在查询和更新时要注意查询的优化策略。

四、实验组织执行要求

本实验为综合型实验。採用集中授课形式,学生集中上机操作。详细要求例如以下:

1、学生在进行实验前必须进行充分的预习,熟悉实验内容;

2、教师在学生实验过程中予以必要的辅导。学生独立完毕实验。

五、实验条件

1、提供一台具有WINDOWS 98/2000/NT/XP操作系统的计算机。

2、Oracle8.0以上设计环境。

六、实验步骤

类同实验三。

七、思考题

    实验比較IN与Exists两种子查询的差别。

八、实验报告

1.实验预习

在实验前每位同学都须要对本次实验进行认真的预习,并写好预习报告。在预习报告中要写出实验目的、要求、简要的实验步骤,形成一个操作提纲。

2.实验记录

学生開始实验时。应该将记录本放在近旁,将实验中所做的每一步操作、所得结果及相关条件如实地记录下来。

3.实验报告

主要内容包含实验中的查询语句、数据更新语句、执行结果以及对操作过程中出现错误的分析总结。回答思考题,给出实验结论。

九、其他说明

学生严格遵守实验室的各项规章制度,配合和服从实验室人员管理。

经过试验 我们也得到了实验的结果

注意这个两个SQL实验脚本是基于实验一中的两个数据库的

代码例如以下,进过验证 实验没有错误 基本的是双NOT EXISTS 具体的解答见我的博客还有一章节

--2.1---------------------------------------------------------------------------------------
select SNO FROM SPJ
WHERE JNO='J1';

select SNO FROM SPJ
WHERE JNO='J1'AND PNO='P1';

select SPJ.SNO FROM SPJ,P
WHERE SPJ.JNO='J1'AND SPJ.PNO=P.PNO AND COLOR='红';

SELECT DISTINCT SPJ.JNO FROM SPJ,S,P
WHERE SPJ.SNO=S.SNO AND SPJ.PNO=P.PNO
      AND S.CITY!='天津' AND P.COLOR!='红';

SELECT DISTINCT JNO
FROM  J
WHERE NOT EXISTS
   (
      SELECT *
      FROM SPJ SPJ1
      WHERE SPJ1.sno='S1' AND NOT EXISTS
      (
        SELECT *
        FROM SPJ SPJ2
        WHERE SPJ2.pno= SPJ1.pno AND SPJ1.jno= J.jno
      )
   );

SELECT SPJ.SNO,COUNT(*) FROM SPJ
GROUP BY SPJ.SNO;

SELECT SPJ.JNO FROM SPJ
GROUP BY SPJ.JNO
HAVING COUNT(*) >=3;

UPDATE  P
SET COLOR='粉红'
WHERE COLOR='红';

UPDATE SPJ
SET SNO='S2'
WHERE SNO='S1' AND JNO='J1' AND PNO='P1';

DELETE SPJ
WHERE SPJ.PNO IN
            (
              SELECT P.PNO FROM p
              WHERE P.COLOR='红'
            );

DELETE  P
WHERE P.COLOR='红';

--2.2---------------------------------------------------------------------------------
SELECT MODEL
FROM PC
WHERE SPEED >= 150;

SELECT DISTINCT PRODUCT.MAKER FROM PRODUCT,LAPTOP
WHERE PRODUCT.MODEL=LAPTOP.MODEL AND LAPTOP.HD >= 1.0;

SELECT MAKER,PRODUCT.MODEL,PRICE
FROM PRODUCT,PC
WHERE PRODUCT.MAKER='B' AND PRODUCT.model=PC.model
UNION
(
SELECT MAKER,PRODUCT.MODEL,PRICE
FROM PRODUCT,LAPTOP
WHERE PRODUCT.MAKER='B' AND PRODUCT.model=LAPTOP.model
)
UNION
(SELECT MAKER,PRODUCT.MODEL,PRICE
FROM PRODUCT,PRINTER
WHERE PRODUCT.MAKER='B' AND PRODUCT.model=PRINTER.model
);

SELECT MODEL FROM PRINTER
WHERE COLOR='TRUE';

SELECT DISTINCT PRODUCT.MAKER
FROM PRODUCT,PC
WHERE TYPE='PC' AND PRODUCT.MODEL=PC.MODEL AND SPEED>450;

SELECT  * FROM PRINTER
WHERE PRICE >= ALL
(
  SELECT PRICE  FROM PRINTER
);

SELECT MODEL,PRICE
FROM PRINTER
WHERE PRICE=
(
  SELECT MAX(PRICE) FROM PRINTER
);

SELECT DISTINCT MAKER,MAX(PRICE)
FROM PRODUCT ,PC
WHERE PRODUCT.MODEL=PC.MODEL AND TYPE='PC'
GROUP BY MAKER;

SELECT DISTINCT MAKER,COUNT(*) FROM PRODUCT
WHERE TYPE='PC'
GROUP BY MAKER
HAVING COUNT(*)>=3;

UPDATE PRODUCT
SET MAKER='B'
WHERE MAKER='A';

DELETE PRODUCT P1
WHERE P1.TYPE='LAPTOP' AND EXISTS
(
  SELECT * FROM PRODUCT P2
  WHERE P2.TYPE='Printer'
  AND P1.MODEL=P2.MODEL
);

ROLLBACK;

如有不当之处还请多多不吝赐教...

本人劳动成果,还请转载署名出处。。。

时间: 2024-12-27 07:32:45

ORACLE 实验二的相关文章

ORACLE 实验一

实验一:数据定义 实验学时:4学时 实验类型:综合型 实验要求:必修 一.实验目的 1.熟悉Oracle的客户端配置: 2.掌握SQL Plus的使用: 3.掌握SQL模式定义语句,定义相关的表.索引与完整性约束. 二.实验内容 1 Oracle的使用 Oracle数据库管理系统采用客户机/服务器结构,客户端上需要配置数据库网络服务命名.在操作系统的"开始"菜单的"Oracle"程序组中,找到并运行"Net8".查看其中的服务命名配置是否与服务器

MySQL数据库实验二:单表查询

实验二   单表查询 一.实验目的 理解SELECT语句的操作和基本使用方法. 二.实验环境 是MS SQL SERVER 2005的中文客户端. 三.实验示例 1.查询全体学生的姓名.学号.所在系. SELECT Sname,S#,Sdept FROM S: 2.查询全体学生的详细记录. SELECT  * FROM S: 3.查全体学生的姓名及其出生年份. SELECT Sname,2011-Sage    /*假定当年的年份为2011年*/ FROM S: 4.查询选修了课程的学生学号.

20145221高其&20145326蔡馨熠《信息安全系统设计基础》实验二 固件设计

20145221高其&20145326蔡馨熠<信息安全系统设计基础>实验二 固件设计 实验目的与要求 了解多线程程序设计的基本原理,学习 pthread 库函数的使用. 了解在 linux 环境下串行程序设计的基本方法. 掌握终端的主要属性及设置方法,熟悉终端I /O 函数的使用.学习使用多线程来完成串口的收发处理. 熟悉linux开发环境,学会基于S3C2410的linux开发环境的配置和使用.使用linux的armv4l-unknown-linux-gcc编译,使用基于NFS方式的

实验二 作业调度模拟程序

实验二 作业调度模拟程序 一.        实验目的 (1)加深对作业调度算法的理解: (2)进行程序设计的训练. 二.        实验内容和要求 用高级语言编写一个或多个作业调度的模拟程序. 单道批处理系统的作业调度程序.作业一投入运行,它就占有计算机的一切资源直到作业完成为止,因此调度作业时不必考虑它所需要的资源是否得到满足,它所运行的时间等因素.      作业调度算法: 1)      采用先来先服务(FCFS)调度算法,即按作业到达的先后次序进行调度.总是首先调度在系统中等待时间

实验二

实验二.pcb进程 专业 网络工程   姓名 方俊晖 学号 201406114309 一.        实验目的 通过本实验可以加深对有关进程控制块.进程队列的概念的进一步理解. 二.        实验内容和要求 1.进程PCB的结构体定义 2.定义结构体 3.输入进程序列 4.排序(按到位时间) 5.输出进程运行的结果 三.        实验方法.步骤及结果测试 #include<stdio.h>typedef struct PCB{int time;int member;int he

信息安全系统设计基础实验二:固件设计

北京电子科技学院(BESTI) 实验报告 课程:信息安全系统设计基础 班级:1353 姓名:芦畅 傅冬菁 学号:20135308 20135311 成绩: 指导教师:娄家鹏 实验日期:2015.11.10 实验密级: 预习程度: 实验时间:15:30~18:00 仪器组次: 必修/选修: 实验序号:1 实验名称:实验一:Linux开发环境的配置和使用 实验目的与要求: 1.掌握程序的烧写方法; 2.能够实现Bootloader; 3.实现密码学中常见算法的固化. 实验仪器: 名称 型号 数量 嵌

实验二 实验报告

实验二 作业调度模拟程序 13物联网  陈梓帆  201306104108 一.目的和要求 1. 实验目的 (1)加深对作业调度算法的理解: (2)进行程序设计的训练. 2.实验要求 用高级语言编写一个或多个作业调度的模拟程序. 单道批处理系统的作业调度程序.作业一投入运行,它就占有计算机的一切资源直到作业完成为止,因此调度作业时不必考虑它所需要的资源是否得到满足,它所运行的时间等因素. 作业调度算法: 1) 采用先来先服务(FCFS)调度算法,即按作业到达的先后次序进行调度.总是首先调度在系统

1111实验二 作业调度模拟实验

实验二.作业调度模拟实验 物联网工程 张怡 201306104149 一.实验目的  (1)加深对作业调度算法的理解: (2)进行程序设计的训练. 二.实验内容和要求 1.至少用三种调度算法: 1) 采用先来先服务(FCFS)调度算法,即按作业到达的先后次序进行调度.总是首先调度在系统中等待时间最长的作业. 2) 短作业优先 (SJF) 调度算法,优先调度要求运行时间最短的作业. 3) 响应比高者优先(HRRN)调度算法,为每个作业设置一个优先权(响应比),调度之前先计算各作业的优先权,优先数高

实验二十四:SD卡模块

  驱动SD卡是件容易让人抓狂的事情,驱动SD卡好比SDRAM执行页读写,SD卡虽然不及SDRAM的麻烦要求(时序参数),但是驱动过程却有猥琐操作.除此此外,描述语言只要稍微比较一下C语言,描述语言一定会泪流满面,因为嵌套循环,嵌套判断,或者嵌套函数等都是它的痛.. 史莱姆模块是多模块建模的通病,意指结构能力非常脆弱的模块,暴力的嵌套行为往往会击垮模块的美丽身躯,好让脆弱结构更加脆弱还有惨不忍睹,最终搞垮模块的表达能力.描述语言预想驾驭SD卡,关键的地方就是如何提升模块的结构能力.简单而言,描述