postgresql函数结合for循环使用

Postgresql 函数例子)

本业务是实现将之前已经使用的数据和现在的数据关联起来,需要写个sql函数初始化数据,数据库使用的是postgresql

具体代码

create or replace function insert_user_roles()
returns void as $$
declare
  user RECORD;
  role RECORD;
begin
  for user in (select id from user where is_delete = false) loop
    for role in (select * from role where is_delete = false) loop
      insert into '实际要插入数据的表' ('字段')
      values
      (user.id, role.id);
    end loop;
  end loop;
end;
$$ language plpgsql;

select insert_user_roles();;

语法

业务需求是为已经在使用的用户初始化数据(模拟需求),学习语法就行,业务代码可以忽略掉。

loop关键字不能忽略,且要跟for循环对应上
声明的变量需要使用declare
begin end要对应上
因为我这个业务场景是不需要返回值的,如果需要有返回值的可以去参考pgsql文档也不是很难
查询*完全就是为了方便,实际业务操作建议不要这么操作

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值