`

Oracle 问答题 PLSQL块

 
阅读更多
1.未命名的PL/SQL块是匿名块,已命名的PL/SQL块是什么?
--过程
---------------------------------------------------------
2.有表student(name varchar2(20),age number(3,0),address varchar2(30))
  在插入部分记录之后,请建立存储过程getInfo,并可通过参数学生姓名来得到学生信息。
--先删除表
drop table student
--建立表
create table student(name varchar2(20),age number(3,0),address varchar2(30))
--插入信息
insert into student values('aaa',56,'abcdefg');
insert into student values('bbb',23,'abcdefg');
insert into student values('ccc',35,'abcdefg');
insert into student values('ddd',56,'abcdefg');
insert into student values('eee',23,'abcdefg');
insert into student values('fff',35,'abcdefg');
insert into student values('ggg',56,'abcdefg');
insert into student values('hhh',23,'abcdefg');
insert into student values('iii',35,'abcdefg');
--查询表
select * from student
--建立过程
create or replace procedure pro_getinfo(sname varchar2)
as
  s_address varchar2(20);
  begin
   select address into s_address from lee.student where name = sname;
   dbms_output.put_line(s_address);
  end;
declare
  sname varchar2(20) := 'aaa';
begin
  pro_getinfo( sname);
end;
---------------------------------------------------------
3.请修改上一存储过程,将address通过参数输出?并写出块来测试此过程?

create or replace procedure pro_getinfo( sname varchar2,address out varchar2,age out number )
as

  begin
    select address ,age into address,age from lee.student where name = sname;
      dbms_output.put_line('地址是'||address||'年龄是'||age);
  end;

declare
  saddress varchar2(30) ;
  sage number(3,0);
begin
  pro_getinfo('aaa',saddress,sage);
  dbms_output.put_line(saddress||'年龄是'||sage);
end;

select * from student where name = 'aaa'

---------------------------------------------------------
5.函数与过程的主要区别是什么?

过程                      函数
作为PL/SQL语句执行        作为表达式的一部分调用
在规范中不包含return子句  必须在规范中包含return子句
不返回任何值              必须返回单个值
可以只有return是用来返回  必须包含至少一条return语句
---------------------------------------------------------
6.有表studentmark(stuid varchar2(5),clsid varchar2(19),mark number(3,0))
  在插入部分记录之后
  请写函数来获得某个学号参加考试的次数。
  并测试结果
create table studentmark(stuid varchar2(5),clsid varchar2(19),mark number(3,0))
select * from studentmark
insert into studentmark values('aa','SQL',90);
insert into studentmark values('aa','Java',89);
insert into studentmark values('aa','Oracle',75);
insert into studentmark values('aa','C#',58);
insert into studentmark values('bb','JSP',24);

create or replace function fun_numcount(sid varchar2)
return number as counts number;
begin
select  count(*) into counts from studentmark where stuid = sid;
return counts;
  dbms_output.put_line(counts);
end;

declare num1 number;
begin
num1 := fun_numcount('aa');
dbms_output.put_line('这个学号的考生考试的次数是:'||num1||'次');
end;

---------------------------------------------------------
7.函数可以有out,或out in 类型的参数吗?它的参数与返回值类型有要求吗?
--可以是 输入输出型的
--不可以的
8.请写一函数获得三个数的最大数?并测试之
create or replace function fun_getmaxnumber(num1 number,num2 number,num3 number)
return number as maxvalues number;
begin
if((num1 > num2)and(num1>num3))
then
  return num1;
elsif((num2 > num3)and(num2>num1))
then
   return num2;
else
   return num3;
end if;
end;

declare num number;
begin
num := fun_getmaxnumber(99999999999,10000,8999);
   dbms_output.put_line('最大数是:'||num);
end;
--------------------------------------------------------------------
10.要声明自主事务处理要使用哪个声明?自主事务的特点是什么?
pragma autonomous_transaction;
特点是:
a.处理结果的变化不依赖于主事物处理的状态或最终配置;
b.自主事物提交或回滚时不我待不影响主事物的结果
c.自主事物一旦提交,用户可以访问以更新的信息,而无需等待主事物处理提交
d.自主事物处理可以启动其他自主事物处理
---------------------------------------------------------------------
11.程序包是什么?它包括哪两部分?
  程序包是一种数据库对象,对相关PL/SQL类型,子程序,游标,异常,变量和常量的封装。

  包括 程序包主体 和 程序包规范
---------------------------------------------------------------------
12.有表studentinfo(stuid varchar2(5),stuname varchar2(20),stuphone varchar2(12),stuaddress varchar2(50))
   表stumark(stuid varchar2(5),clsid varchar2(10),mark number)
   插入部分数据后
   创建包规范
        定义函数来获得某个学生,某门课程的成绩
        定义函数来获得某个学生所有课程的平均成绩
        定义函数来获得某个学生最差的科目
   创建包体来实现上述函数。
   测试上述函数
   请查询出所有学生的信息加上该生vb的考试成绩.

create table studentinfo(stuid varchar2(5),stuname varchar2(20),stuphone varchar2(12),stuaddress varchar2(50))
create table stumark(stuid varchar2(5),clsid varchar2(10),mark number)

insert into studentinfo values('1','aaa','139123456789','秦皇岛海港区');
insert into stumark values('1','VB',89);
insert into stumark values('1','SQL',90);

create or replace package pack_test
as
  function fun_getinfo(ids varchar2) return stumark%rowtype;
end pack_test;

create or replace package body pack_test as
function fun_getinfo(ids varchar2) return stumark%rowtype is info stumark%rowtype;
   begin
     select * into info from stumark where stuid = ids;
     dbms_output.put_line(info.stuid||info.clsid);
     return info;
  end;

end pack_test;

declare
info varchar2(30);
begin
select pack_test.fun_getinfo('1') into info from dual ;
end;

declare
info stumark%rowtype;
begin
  info := pack_test.fun_getinfo('1');
end;
----------------------根据一个人名获取他的各科成绩------------------------------------
--建立一个包
select * from view_stu
create or replace package pack_test
is
  cursor cur_test(sname varchar2) return view_stu%rowtype;
  procedure proc_test(sname varchar2);
end pack_test;
create or replace package body pack_test
is
  cursor cur_test(sname varchar2) return view_stu%rowtype is select * from view_stu where stuname = sname;
  procedure proc_test(sname varchar2) is
   begin
    dbms_output.put_line('姓名是'||sname);
    dbms_output.put_line('--------------------------------------');
   for ee in cur_test(sname)
   loop
    dbms_output.put_line('科目是'||ee.clsid||'分数是'||ee.mark);
   end loop;
   end;
  end;
begin
pack_test.proc_test('aaa');
end;
--所有学生的信息加上该生vb的考试成绩.
select a.*,b.mark from studentinfo a,stumark b
where a.stuid = b.stuid and b.clsid = 'vb';
--------------------------------------------------------------------
13.在pl/sql块中可以使用包中的变量吗?哪此部分可以使用,哪些部分不可用?
  公有元素在规范中定义,私有元素在程序包主体中定义。
  私有元素不能在程序包之外引用。程序包中的任何其他元素均可以引用和使用私有元素。
  可以,公有元素可以访问,私有的不能访问。
---------------------------------------------------------------------
14.在程序中如何定义和使用游标?
见12题吧
  --------------------------------------------------------------------
15.建立包规范与包主体,定义游标curStuMark来获得某学生的各科考试成绩信息。表如题12.并定义与实现过程来显示该学生的科目与分数信息。如
   vb   80
   sql  95....
   ----------------------根据一个人名获取他的各科成绩------------------------------------
--建立一个视图
create or replace view view_stu as
select i.stuid,i.stuname,m.clsid,m.mark from stumark m, studentinfo i
  where m.stuid = i.stuid(+)
--建立一个包
select * from view_stu
create or replace package pack_test
is
  cursor cur_test(sname varchar2) return view_stu%rowtype;
  procedure proc_test(sname varchar2);
end pack_test;
create or replace package body pack_test
is
  cursor cur_test(sname varchar2) return view_stu%rowtype is select * from view_stu where stuname = sname;
  procedure proc_test(sname varchar2) is
   begin
    dbms_output.put_line('姓名是'||sname);
    dbms_output.put_line('--------------------------------------');
   for ee in cur_test(sname)
   loop
    dbms_output.put_line('科目是'||ee.clsid||'分数是'||ee.mark);
   end loop;
   end;
  end;
begin
pack_test.proc_test('aaa');
end;
  --------------------------------------------------------------------
16.请问题15定义的游标在包之外可以用吗,测试之?实现同15题过程显示的相同结果。
可以用。
  --------------------------------------------------------------------
17.由15,16题我们可以看出什么呢,(是不是我们可以将我们经常要用到的一些游标也可放入包中供将来直接使用)。
是的
  --------------------------------------------------------------------
18.包信息保存在哪个数据词典中。
user_objects
---------------------------------------------------------------------------------------------
19.关于自主事务处理的问题 子事物会执行自己的commit 如下

select * from studentmark

create or replace procedure p2
as
begin
update  studentmark set mark = 66 where stuid = 'bb';
commit;
end;


create or replace procedure p1
as pragma autonomous_transaction;
begin
update  studentmark set mark = 100 where stuid = 'bb';
p2;
rollback;
end;

begin
p1;
end;
分享到:
评论

相关推荐

    Oracle连接工具plsql11x64位

    Oracle连接工具plsql11x64位Oracle连接工具plsql11x64位Oracle连接工具plsql11x64位Oracle连接工具plsql11x64位Oracle连接工具plsql11x64位Oracle连接工具plsql11x64位Oracle连接工具plsql11x64位Oracle连接工具...

    64位ORACLE客户端上plsql无法识别ORACLE_HOME解决方案

    ### 64位ORACLE客户端上plsql无法识别ORACLE_HOME解决方案 #### 问题背景 在当前的技术环境中,大部分桌面操作系统已经升级至64位版本,这也促使许多软件包括Oracle客户端倾向于采用64位版本。然而,Pl/SQL ...

    不安装oracle使用plsql

    标题中的“不安装oracle使用plsql”意味着要在没有Oracle数据库客户端的情况下使用PL/SQL Developer这一工具。这通常通过Oracle的Instant Client实现,该组件提供了一种轻量级的解决方案,允许用户连接到Oracle...

    (ORACLE)PLSql

    PLSql 很好的一个控制数据库工具(ORACLE)

    精通Oracle 10g PLSQL编程

    Oracle 10g PLSQL编程是数据库管理员和开发人员必须掌握的关键技能之一。PL/SQL,全称为Procedural Language/Structured Query Language,是Oracle数据库系统中的过程化语言,它结合了SQL的查询功能和传统编程语言的...

    PLSQL Developer7(oracle数据库)

    PLSQL Developer7(oracle数据库) PLSQL Developer7(oracle数据库) PLSQL Developer7(oracle数据库) PLSQL Developer7(oracle数据库) PLSQL Developer7(oracle数据库) PLSQL Developer7(oracle数据库) ...

    windows下oracle客户端及PLsql安装配置(含安装包)

    在Windows环境下,Oracle客户端和PL/SQL Developer是数据库管理员和开发人员进行Oracle数据库管理与开发的重要工具。本文将详细介绍这两个工具的安装与配置过程,包括11g和12c两个版本的Oracle客户端。 首先,我们...

    精通Oracle10g PLSQL编程.rar

    - **块结构**:PLSQL由声明、执行和异常处理三个部分组成的块,理解这些块的作用和编写规则。 - **游标**:用于处理SQL查询结果集,通过游标可以逐行处理数据,是数据库操作中的重要工具。 2. **PLSQL函数和过程*...

    oracle操作工具PLSQL

    带注册机 oracle操作工具PLSQL 很实用

    PLSql远程连接Oracle

    使用PLSql远程连接Oracle,其中包含了Oracle客户端和PLSql32位。使用PLSql远程连接Oracle,其中包含了Oracle客户端和PLSql32位。使用PLSql远程连接Oracle,其中包含了Oracle客户端和PLSql32位。

    oracle客户端(plsql developer连接远程数据库)

    plsql developer连接远程数据库(本地不用安oracle)

    PLSQL oracle连接工具

    PLSQL oracle连接工具 PLSQL oracle连接工具 PLSQL oracle连接工具 PLSQL oracle连接工具 PLSQL oracle连接工具 PLSQL oracle连接工具 PLSQL oracle连接工具 PLSQL oracle连接工具 PLSQL oracle连接工具 PLSQL ...

    《Oracle PLSQL 从入门到精通》.zip

    Oracle PLSQL,全称为“Procedural Language/Structured Query Language”,是Oracle数据库系统中的一个强大编程语言,它结合了SQL的查询能力与过程性编程语言的功能。本资料《Oracle PLSQL 从入门到精通》旨在帮助...

    Oracle12c客户端+plsql12

    Oracle 12c是Oracle公司推出的数据库管理系统的一个版本,它在前一版本的基础上进行了一系列的改进和优化,旨在提供更高的性能、可扩展性和安全性。PL/SQL是Oracle数据库附带的一种过程编程语言,用于编写数据库应用...

    Oracle Web Applications PLSQL Developer's Introduction

    This book is an easy-to-understand guide to building Oracle8i (Oracle's "Internet database") Web applications using a variety of tools -- PL/SQL, HTML, XML, WebDB, and Oracle Application Server (OAS)....

    精通Oracle10g PLSQL编程.

    如果你想学PLSQL,你可以不用花钱买书了,这本书绝对是你学习PLSQL的好帮手。

    oracle64位PLSQL developer安装

    4. 下载Oracle PL/SQL Developer的64位安装包,例如“PLSQL Developer.rar”。 二、安装过程 1. 解压下载的“PLSQL Developer.rar”文件,得到安装文件夹。 2. 打开文件夹,找到并双击运行“setup.exe”启动安装...

    PLSQL Developer 12 (32位)中文绿色注册版免Oracle客户端版1

    PLSQL Developer 11.0.2.1766 中文绿色注册版(免Oracle客户端) PLSQL Developer 11.0.2.1766 中文绿色注册版(免Oracle客户端) 免安装Oracle客户端,绿色无公害。 说明: 1、点击 "启动PLSQL.exe" 即可免装oracle使用...

    Oracle 10g PLSQL

    Oracle 10g PLSQL

    免安装Oracle客户端使用PLSQL

    免安装Oracle客户端使用PLSQL . 利用oracle 发布的Instant Client 安装包. http://www.oracle.com/technetwork/database/features/instant-client/index-097480.html 已测试正常可用,全国推广.

Global site tag (gtag.js) - Google Analytics