游标和触发器练习

declare
cursor c_cursor is
select * from ruanjian181;
– v_info ruanjian181%rowtype;
begin
– open c_cursor;
for v_info in c_cursor loop
dbms_output.put_line(v_info.age);
end loop;
– close c_cursor;
end;

declare
cursor lr_num is --定义一个游标,名为:lr_num
select level lv
from dual
connect by level <= 5; --这段查询即为游标lr_num的具体内容
v_num lr_num%rowtype; --定义一个变量v_num,数据类型为游标 lr_num 的 %ROWTYPE,即lr_num的一行
begin
open lr_num; --打开游标lr_num
loop --开始循环
fetch lr_num into v_num; --把游标 lr_num 中的next一行数据 into 到变量 v_num 中
exit when lr_num%notfound; --如果 lr_num 中找不到next一行数据,即退出循环
dbms_output.put_line(v_num.lv); --输出 v_num 变量中的 lv 字段的值
end loop; --结束循环
close lr_num; --关闭游标
end;

–触发器练习
–复制表头
CREATE TABLE dept_log AS SELECT * FROM ruanjian181 WHERE 1=2;
select * from dept_log;

–登录触发器练习
create or replace trigger logon_trigger
after logon on database
begin
insert into log_event(log_type,username,logonTime)
values(‘logon’,ora_login_user,sysdate);
end;
–登出触发器
create or replace trigger logoff_trigger
before logoff on database
begin
insert into log_event(log_type,username,logoffTime)
values(‘logoff’,ora_login_user,sysdate);
end;
–创建日志记录表
create table log_event(
log_type varchar2(20),
username varchar2(20),
logonTime date,
logoffTime date
);

select * from log_event;

create table student2(
sno varchar2(10) primary key,
sname varchar2(20),
sage number(2),
cno varchar2(2)
);
create table student2bei(
sno varchar2(10) primary key,
sname varchar2(20),
sage number(2),
cno varchar2(2)
);

insert into student2 values(‘1’,‘lilia’,18,‘1’);
insert into student2 values(‘2’,‘lilib’,18,‘1’);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值