hs_bj 2019-07-15 20:00 采纳率: 33.3%
浏览 301
已采纳

Oracle存储过程的创建怎么破

图片说明
有员工表和部门表
创建存储过程, 员工新进一个部门时,部门表对应部门人数加1,员工调换部门时,原先部门人数减1,现在部门人数加1

图片说明

  • 写回答

3条回答 默认 最新

  • 旅人Maple 2019-07-16 04:09
    关注
    CREATE OR REPLACE PROCEDURE ap.update_data (var_emp       IN     VARCHAR2,
                                                var_new_dpt     IN     VARCHAR2,
                                                var_omsg         OUT VARCHAR2)
    AS
       l_exit      EXCEPTION;
       l_count     INT;
       l_old_dpt   VARCHAR2 (50);
    ----table : emp_table   dpt _able
    BEGIN
       SELECT COUNT (*)
         INTO l_count
         FROM emp_table
        WHERE empname = var_emp;
    
       IF l_count <= 0
       THEN
          var_o_msg := 'emp not exists';
          RAISE l_exit;
       END IF;
    
       SELECT dptid
         INTO l_old_dpt
         FROM emp_table
        WHERE empname = var_emp;
    
       UPDATE dpt_table
          SET dptnumber = dptnumber + 1
        WHERE (dptid = var_new_dpt or dptname =var_new_dpt);--看你传入参数是部门id还是名称
    
       UPDATE dpt_table
          SET dptnumber = dptnumber - 1
        WHERE dptid = l_old_dpt;
    
       var_omsg := 'information updated ';
       COMMIT;
       RETURN;
    EXCEPTION
       WHEN l_exit
       THEN
          ROLLBACK;
          RETURN;
       WHEN OTHERS
       THEN
          ROLLBACK;
    END;
    

    随手写的,用触发器其实更好一点,没必要写什么存储过程。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 已采纳回答 10月11日

悬赏问题

  • ¥15 关于#网络安全#的问题:求ensp的网络安全,不要步骤要完成版文件
  • ¥15 可否在不同线程中调用封装数据库操作的类
  • ¥20 使用Photon PUN2解决游戏得分同步的问题
  • ¥15 微带串馈天线阵列每个阵元宽度计算
  • ¥15 keil的map文件中Image component sizes各项意思
  • ¥20 求个正点原子stm32f407开发版的贪吃蛇游戏
  • ¥15 划分vlan后,链路不通了?
  • ¥20 求各位懂行的人,注册表能不能看到usb使用得具体信息,干了什么,传输了什么数据
  • ¥15 Vue3 大型图片数据拖动排序
  • ¥15 Centos / PETGEM