【问题标题】:implementing horizontally fragmented tables in pl/sql procedure在 pl/sql 过程中实现水平碎片表
【发布时间】:2019-10-08 19:14:26
【问题描述】:

我有两个 tables.account 在 server 和 account1 在 site ,它们具有相同的属性但不同的数据。

创建表帐户(
Accno int, 平衡int, Acctype varchar2(20), Accbranch varchar2(20), 主键(Accno));

创建表帐户1(
Accno int, 平衡int, Acctype varchar2(20), Accbranch varchar2(20), 主键(Accno));

现在我希望创建一个程序来进行银行提款交易。用户将输入一个帐号,该帐号可能来自 account 表或 account1 表以及提款金额。然后该过程将更新该特定表中的余额,该表具有用户提供的帐号作为输入。 我的代码对于一个表来说是可以的。但无法理解如何处理两个水平碎片表(帐户和帐户 1)。 任何人都可以建议我找到解决方案的更好方法。 这是我的程序

CREATE OR REPLACE  PROCEDURE test(x IN number, y IN number)
AS
    cur_balance number;
    new_balance number;

BEGIN
    select Balance into cur_balance
    from Account  
    where Accno = x;

if (cur_balance < y)then
    dbms_output.put_line('Insufficient balance');
else
    new_balance:=cur_balance-y;
    update Account
    set Balance = new_balance
    where Accno = x;

end if; 
    dbms_output.put_line('Money has been withdrawn successfully');
    dbms_output.put_line('Current Balance:' || new_balance);
commit;
END;
/ 

【问题讨论】:

    标签: plsql procedure


    【解决方案1】:

    检查两个表;如果accno 不存在于一个中,我认为no_data_found 被提出。然后检查另一个。

    这是一个例子:

    CREATE OR REPLACE  PROCEDURE test(x IN number, y IN number)
    AS
        cur_balance number;
        new_balance number;
        which_table varchar2(20);
    BEGIN
      begin
        select Balance 
          into cur_balance
          from Account 
          where Accno = x;
    
        which_table := 'account';
      exception
        when no_data_found then
          -- ACCNO wasn't found in ACCOUNT, so - check ACCOUNT1
          select balance
            into cur_balance
            from account1
            where accno = x;
    
          which_table := 'account1';        
      end;
    
      if (cur_balance < y)then
         dbms_output.put_line('Insufficient balance');
      else
         new_balance := cur_balance - y;
    
         if which_table = 'account' then
            update Account
              set Balance = new_balance
              where Accno = x;
         else
            update account1
              set balance = new_balance
              where accno = x;
         end if;
    
         dbms_output.put_line('Money has been withdrawn successfully');
         dbms_output.put_line('Current Balance:' || new_balance);
    
         commit;
      end if;  
    END;
    / 
    

    【讨论】:

    • 它的工作。感谢分享您的想法。是否可以通过在两个表之间使用联合或其他操作找到解决方案? :)
    • 不客气。联盟?好吧,您可以以某种方式 获取当前余额,但关键是如何知道要更新哪个表。我想我发布的代码非常简单且易于维护,所以 - 我不会让它复杂化。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2012-10-28
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-09-25
    • 2010-10-16
    • 2021-12-04
    相关资源
    最近更新 更多