postgresql 触发器函数,触发器,游标的使用范例

**

postgresql 触发器函数,触发器,游标的使用范例

一、 触发器函数:

记录数据数目和修改数据集时间的触发器 :

create or replace function recordNum1() returns trigger as $record_num1$
declare var text;  //定义变量
begin update dataset_type_summary set data_count=(select count(*) from voc2007); 
update dataset_type_summary set create_time = now(); 
var = testCursor();  // 触发器函数调用游标
return new; 
end; 
$record_num1$ 
language plpgsql;

二、触发器的创建:

create trigger recordNum_trigger after insert or delete on database_voc for each row execute PROCEDURE recordNum1();

三、游标的创建:

create or replace function testCursor() returns void as $$ 
declare declare_cursor cursor for select distinct type from image_object where main_id in (select database_id from voc2007); 
var text; 
begin 
open declare_cursor;
fetch declare_cursor into var; 
update dataset_type_summary SET include_type='{}' where id=1; 
while found loop update dataset_type_summary SET include_type = array_append(include_type,var); 
fetch declare_cursor into var; 
end loop; 
close declare_cursor; 
end; 
$$ language plpgsql;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值