- 浏览: 548665 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
beck_iceblock:
[/color][color=white][color=oli ...
MYSQL的group_concat()函数中实现将多行同一字段数据合并成一个数据 -
瞎折腾球:
fristname 和 list name ,email填什么 ...
JetBrain WebStorm 注册码 -
瞎折腾球:
Your license key cannot be foun ...
JetBrain WebStorm 注册码 -
学习学习学习11111:
第一个可用,感谢 ,赞一个
JetBrain WebStorm 注册码 -
ichenwenjin:
不错,能用
JetBrain WebStorm 注册码
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;
--过程
---------------------------------------------------------
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;
发表评论
-
MYSQL 禁用主外键约束
2016-04-09 17:30 788我们可以使用 SET FOREIGN_KEY_CHEC ... -
清空具有外键约束的表时报ERROR 1701(42000)的解决
2015-10-13 17:16 552清空具有外键约束的表时报ERROR 1701(42000)的解 ... -
常用的Oracle DCL 命令语句
2014-01-02 15:47 1024常用的Oracle DCL 命令语句 Oracle修改字段 ... -
REF 动态SQL游标
2013-11-05 00:20 744declare tb_count number; ... -
Oracle 创建表空间与用户
2013-11-03 14:13 6781.表空间创建 create tablespace pic ... -
Oracle 定时器写法
2013-09-22 10:21 938--定义一个规则 --如果是定时轮询的job 下面 subm ... -
MYSQL的group_concat()函数中实现将多行同一字段数据合并成一个数据
2012-09-05 20:37 11276数据表 出访团组表 select a.t_applyper ... -
MS-SQL2008的配置与JDBC连接
2012-05-25 16:44 1052MS SQLSERVER 2008 SA 身份配置 http ... -
Win7 下安装Oracle10G
2012-04-28 08:39 1573Win7 下安装Oracle 10G 需要注意事项 Oracl ... -
巧用SQL中的 like 进行表与表之间的关联!
2011-09-28 08:56 3170create view sys_orgp as selec ... -
MYSQL INDEXOF用法
2011-09-27 17:05 23410LOCATE(substr,str) 返回子串substr ... -
MySQL 设置全局变量
2011-08-22 08:48 1977ERROR 1418 (HY000): This funct ... -
只有 Oracle 11G 支持的 unpivot函数
2011-03-29 17:19 2443只有Oracle 11G才支持的行列转置的函数 UNPIVOT ... -
Oracle 用 decode 函数进行行列转置
2011-03-29 16:22 8688当你面对如下格式的一个表格:NO为人员的ID,MONEY是收入 ... -
MYSQL数据库备份与恢复命令
2011-01-10 10:48 856备份: mysqldump -u[user] -p[passw ... -
巧用 like 进行关联
2010-09-16 16:45 892select b.d_c_name,a.t_id fro ... -
人员sql语句
2010-09-06 17:10 805select count(nvl2(substr(a.t_ ... -
比较复杂的SQL交叉表语句
2010-09-05 18:14 1315select * from ( select t.cl_ ... -
Oracle 获取时间段内的 日期列表 和时间列表
2010-09-05 10:27 2627本文来自 http://xuwang840901.blog.1 ...
相关推荐
Oracle连接工具plsql11x64位Oracle连接工具plsql11x64位Oracle连接工具plsql11x64位Oracle连接工具plsql11x64位Oracle连接工具plsql11x64位Oracle连接工具plsql11x64位Oracle连接工具plsql11x64位Oracle连接工具...
windows下oracle客户端及PLsql安装配置(含11g、12c的客户端安装包,plsql安装包)
不安装oracle客户端,配置plsql连接数据库
PLSql 很好的一个控制数据库工具(ORACLE)
PLSQL Developer7(oracle数据库) PLSQL Developer7(oracle数据库) PLSQL Developer7(oracle数据库) PLSQL Developer7(oracle数据库) PLSQL Developer7(oracle数据库) PLSQL Developer7(oracle数据库) ...
在不安装oracle客户端的前提下,是用plsql,实现方法。
精通Oracle 10g PLSQL编程
Plsql到目前为止只有32位的程序,而大多数的桌面... 操作系统,在64位的windows上,大多数情况下也是安装64位的ORACLE client程序,这种组合,导致plsql无法识别到ORACLE_HOME目录,读取不到tnsnames.ora文件中的连接串
带注册机 oracle操作工具PLSQL 很实用
OracleSQL和PLSQL介绍\介绍OracleSQL和PLSQL.pdf
Oracle数据库11g64位Windows版安装包 OracleClient客户端x64位安装包 Plsql工具x64位
使用PLSql远程连接Oracle,其中包含了Oracle客户端和PLSql32位。使用PLSql远程连接Oracle,其中包含了Oracle客户端和PLSql32位。使用PLSql远程连接Oracle,其中包含了Oracle客户端和PLSql32位。
介绍OracleSQL和PLSQL 希望对大家有帮助
oracle64位PLSQL developer安装 里面有详细的使得方法
这个oracle的客户端PLSQL
plsql developer连接远程数据库(本地不用安oracle)
PLSQL oracle连接工具 PLSQL oracle连接工具 PLSQL oracle连接工具 PLSQL oracle连接工具 PLSQL oracle连接工具 PLSQL oracle连接工具 PLSQL oracle连接工具 PLSQL oracle连接工具 PLSQL oracle连接工具 PLSQL ...
oracle 官方教程 PLSQL Fundamentals
oracle_plsql语句大全oracle_plsql语句大全oracle_plsql语句大全
linux 下Oracle 编程PLSQL编程