PL/SQL


declare---下定义
  i number(2) := 10;
  ena emp.ename%type;---引用型变量
  emprow emp%rowtype;---记录型变量
begin
  dbms_output.put_line(i);---输出变量
  select ename into ena from emp where empno=7788;
  dbms_output.put_line(ena);
  select * into emprow from emp where empno=7788;
  dbms_output.put_line(emprow.ename ||'-'|| emprow.job);
end;

 

---PL/SQL中if判断
---输入小于18的数字,输入未成年
---输入18~40之间,输出中年人
---输入大于40的数字,输出老年人
declare
  i number(3) := &i;--输入变量
begin
  if i<18 then
    dbms_output.put_line('未成年');
  elsif i<40 then
    dbms_output.put_line('中年人');
  else
    dbms_output.put_line('老年人');
  end if;
end;


---PL/SQL中的loop循环
---三种方式输出1-10
---while循环
declare
  i number(2) :=1;
begin
  while(i<=10) loop
    dbms_output.put_line(i);
    i := i+1;
  end loop;
end;

---exit循环
declare
  i number(2) :=1;
begin
  loop
  exit when i>10;
    dbms_output.put_line(i);
    i:=i+1;
  end loop;
end;

---for循环
declare

begin
  for i in 1..10
  loop
    dbms_output.put_line(i);
  end loop;
end;


---游标:可以存放多个对象,多行记录
---输出emp表中所有员工的姓名
declare
  cursor c1 is select * from emp;
  emprow emp%rowtype;
begin
  open c1;
    loop
      fetch c1 into emprow;
      exit when c1%notfound;
      dbms_output.put_line(emprow.ename);
    end loop;
  close c1;
end;


---给指定部门员工涨工资
declare
  cursor c2(eno emp.deptno%type)
  is select empno from emp where deptno = eno;
  en emp.empno%type;
begin
  open c2(10);--打开游标给参数
    loop
      fetch c2 into en;
      exit when c2%notfound;
      update emp set sal = sal+100 where empno=en;
      commit;
    end loop;
  close c2;
end;

异常处理

 

 


posted @   格兰芬多剁剁剁  阅读(109)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
点击右上角即可分享
微信分享提示