在 pl/sql 过程中实现水平碎片表
Posted
技术标签:
【中文标题】在 pl/sql 过程中实现水平碎片表【英文标题】:implementing horizontally fragmented tables in pl/sql procedure 【发布时间】: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;
/
【问题讨论】:
【参考方案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;
/
【讨论】:
它的工作。感谢分享您的想法。是否可以通过在两个表之间使用联合或其他操作找到解决方案? :) 不客气。联盟?好吧,您可以以某种方式 获取当前余额,但关键是如何知道要更新哪个表。我想我发布的代码非常简单且易于维护,所以 - 我不会让它复杂化。以上是关于在 pl/sql 过程中实现水平碎片表的主要内容,如果未能解决你的问题,请参考以下文章
我们如何在 Oracle SQL 或 PL/SQL 中实现 Standard Normal CDF?
PL/SQL-表和条件都不同时如何在单个查询中实现多条count语句