- 1、本文档共4页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Oracle_PLSQL入门之案例实践
Oracle?PL/SQL入门之案例实践 前面已经了解了关于PL/SQL编程的基础,本文将结合一个案例来加深对这些知识点的理解。 一. 案例介绍 某数据库有两张表,是关于某公司员工资料、薪水和部门信息的,它们分别是emp表和dept表,两张表的结构如下: 要求如下: 1、按照上表结构建立相应的表,并每张表写入5组合法数据。 2、操纵相关表,使得“技术部”的员工的薪水上涨20%。 3、建立日志,追踪薪水变动情况。 4、建立测试包。 二. 案例的分析与实现 从前面案例的介绍不难看出,要求1考察点为基本SQL语句;要求2主要考察复合查询;要求3是考察触发器的应用;要求4的考察面相对多一些,不仅考察了包的创建,而且也考察了在PL/SQL中的测试方法。了解了这些考察的知识点,就可以一一去解决。 要求1: 首先根据前面表的结构可以创建两张表: ——创建员工表create table emp (emp_id number(5), emp_name varchar2(20), emp_salary number(4)); ——部门表create table dept (dept_id number(3), dept_name varchar2(20), emp_id number(5)); 建立了表之后就可以往表里面写数据了,这里把添加表记录的代码写入到相应的存储过程。/*给emp表添加记录的存储过程*/create or replace procedure ins_table_emp(p_emp_id number,p_emp_name varchar2,p_emp_salary number) asv_emp_id number:=p_emp_id;v_emp_name varchar2(20):=p_emp_name;v_emp_salary number:=p_emp_salary;begin insert into emp values (v_emp_id,v_emp_name,v_emp_salary);end ins_table_emp;/*给dept表添加记录的存储过程*/create or replace procedure ins_table_dept(p_dept_id number,p_dept_name varchar2,p_emp_id number) as v_dept_id number:=p_dept_id; v_dept_name varchar2(20):=p_dept_name; v_emp_id number:=p_emp_id;begin insert into dept values (v_dept_id,v_dept_name,v_emp_id);end ins_table_emp;/*调用相应的存储过程实现记录添加*/begin ins_table_emp(10000,,4000); ins_table_emp(10001,??èy,2300); ins_table_emp(10002,3?t,3500); ins_table_emp(10003,à???,3500); ins_table_emp(10004,á?ò?,3500); ins_table_dept(111,DD?t2?,10000); ins_table_dept(111,DD?t2?,10001); ins_table_dept(111,DD?t2?,10002); ins_table_dept(112,??ê?2?,10003); ins_table_dept(113,êD3?2?,10004);end; 要求2: 给指定部门的员工加薪,这实际上是一个复合查询,首先需要把所有该部门的员工塞选出来,然后对这些员工的薪水进行相应的改动。依照这一思路,代码如下: (需要注意的是:将要加薪的部门作为参数,这样的存储过程更有灵活性。)create or replace procedure add_salary(p_dept_name varchar2) asv_dept_name varchar2(20):=p_dept_name;begin update emp set emp.EMP_SALARY=emp.EMP_SALARY*1.2 where emp.EMP_ID in (select emp.EMP_ID from emp,dept where emp.EMP_ID=dept.EMP_ID and dept.DEPT_ID=??ê?2?);?end add_salary; 要求3: 建立日志对薪水的变动情况形成一个追踪,也就是说,如果对某个职员的薪水进行变更就应该将其相应的变更记录全部记下来。如果对emp表的salary字段
您可能关注的文档
最近下载
- 2024年高空作业考试题库附答案5套(完整版).DOC
- 印刷类原辅料进料检验标准.pdf
- 部编人教版四年级上册《道德与法治》全册教学反思.pdf VIP
- 江苏省南通市2023-2024学年高一上学期语文期中考试试卷(含答案).pdf VIP
- 国家开放大学《中国近现代史纲要》社会实践报告.docx VIP
- 领读经典-现代文学(1)(山东大学)中国大学MOOC慕课 章节测验期末考试答案.docx
- 《幼儿挑食、偏食行为的原因分析及对策》开题报告(含提纲)5800字.doc
- 2022年贵州省高职(专科)分类招生中职生文化综合考试试卷(语数英、含答案).pdf
- 小学语文优秀教学案例.docx VIP
- 冬季血压早达标远离心脑血管疾病-高血压慢性病培训讲座课件PPT.pptx
文档评论(0)