分享
 
 
 

[范例]怎样判断画布中有重复纪录(Forms6i)

王朝other·作者佚名  2008-05-19
窄屏简体版  字體: |||超大  

曾经讨论过check_record_uniqueness函数。不过,这个函数有很多缺陷,导致很难有应用价值。详细请参考本贴的附录部分。

--------------------------------------------------------------------------------

最完美的解决方法:自己编写代码,可以产生精确的报错信息,及检查出新输入数据内的重复问题。

由于when-validate-item 不能使用go_item(),first_record等,而when-new-item-instance却允许,所以,可以这样处理:

以基本表(id主键,name ,remark,20行每页界面)

在id(主键)的下一导航项,设置为check_uniqueness_button.

check_uniqueness_button为这个块内的一个按钮,它的when-new-item-instance担任检查该行的重复情况的功能,代码见本贴附录。

另外,手工按check_uniqueness_button,也会执行这段代码,产生手工检查重复情况的功能。

附录代码:

declare

temprecord number;

tempval varchar2(20);

temp_count number :=0;

BEGIN

go_item('base_table.id');

temprecord := :system.cursor_record;

tempval := :base_table.id;

first_record;

if :system.current_value is not null then ---如果有记录,开始运算

loop

if :base_table.id = tempval and :system.cursor_record temprecord then

temp_count := temp_count + 1;

message('代码有重复,请检查第:' || :system.cursor_record

|| '行,代码:'|| :base_table.id ||',名称:' ||:base_table.name);

message('代码有重复,请检查第:' || :system.cursor_record

|| '行,代码:'|| :base_table.id ||',名称:' ||:base_table.name);

end if;

next_record;

if :system.current_value is null then

exit;

end if;

end loop;

if temp_count = 0 then

message('该行代码没有重复');

end if;

go_record(temprecord);

go_item('base_table.name');

else

message('光标所有行没有代码为空,请先将光标放在有数值的地方');

message('光标所有行没有代码为空,请先将光标放在有数值的地方');

end if;

END;

下载示范点击此处下载armok0110018.zip

--------------------------------------------------------------------------------

附录

check_record_uniqueness 可以检查一个数据块(Data Block)内,主键有无重复的记录。

使用方法举例:

1.Block 上,先设定一个item是主键。

2。在主键字段的 when-validate-item trigger 上,加入如下代码:

check_record_uniqueness;

if not form_sucess then

clear message;

message(数据有重复!");

end if;

以上代码,可以使用户每输入一条记录时,系统自动检查主键有无重复。

优点:速度快,代码简单。

缺点:只能应用于主键。

最致命的缺点:经测试后我发现,它只能检查新输入的数据,与已存盘的数据有无重复。如果新输入的记录与未存盘的记录重复,它不会报警!

使用建议:

1。只可用于比较简单的场合,及用户每次输入的资料数目比较少的情况。如果用户大批量输入:如每次输入几十条,甚至上百条,使用check_record_uniqueness便会心惊胆跳了,因为谁也不能保证 ,新输入的数据内会否有重复。

2。如果不是应用于主键,如果每次用户输入量可能比较大,建议自行编写查重复的代码。

---本文为原创,by armok.

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有