如何检查 table 中的元素是否存在?

How can I check if an element in a table exists?

我正在编写一个 Postgres 函数,它应该连续从 3 个表中删除。

关系是从 mobgroupdata -> mobilenums -> terminals 中删除,当我在 mobgroupdata 中没有元素时,我想从 mobilenums 中删除,然后从终端中删除。但是应该是什么条件。我试过

IF mRec.id != 0,但它没有用,比我用 exists 试过的,它也没有用。此外,当我从数据库中创建 select 语句并且 mobgroupdata 的 id 不存在时,代码会中断,但是当我 select 包含在所有表中的元素时,它可以工作。有谁知道要使它起作用的 if 语句应该是什么?

CREATE OR REPLACE FUNCTION "Delete_From_Terminals_Casc_final12"(
"Id_list" bigint,
"Curuser_id" bigint)
  RETURNS SETOF term_mgd_mobnums AS
$BODY$
declare
  mRec "term_mgd_mobnums"%ROWTYPE;

BEGIN

    for mRec in    select mn."id_terminals", t.sn , t.imei ,t.les ,t.category ,t.model ,t.tswv ,t.status ,t.activation_date ,t.deactivation_date ,t.paytype ,t.ip_address ,t.pin1 ,t.pin2 ,t.puk1 ,t.puk2 ,t.notes ,t.units ,t.validtill, t.responsible_user,t.id_clients,t.currentuser, t.isn,
 md.id_mobilenums, mn.current_status, mn.start_date ,mn.streason ,mn.unit ,mn.mobnumber ,mn.service ,mn.status as mn_status,mn.activator ,mn.responsible_department,mn.date_changed ,mn.reason ,mn.installed_on ,mn.usedby ,mn.regnumber ,mn.responsible_user as mn_responsible_user ,mn.description,
 md.id,md.les1 ,md.les2,md.les3,md.les4,md.les5,md.member1 ,md.member2,md.member3,md.member4,md.member5,md.user1 ,md.user2,md.user3,md.user4,md.user5,md.pass1 ,md.pass2,md.pass3,md.pass4,md.pass5 from terminals t
inner join mobilenums mn on t."id" = mn."id_terminals"
inner join mobgroupdata md on md."id_mobilenums" = mn."id"
where mn."id_terminals" =   
loop    

 IF exists THEN
 PERFORM "Delete_From_Mobgroupdata2"(mRec.id,);
 PERFORM "Delete_From_Mobilenums"(mRec.id_mobilenums::text,);
 PERFORM "Delete_From_Terminals"(mRec.id_terminals::text,);
     ELSE
 PERFORM "Delete_From_Mobilenums"(mRec.id_mobilenums::text,);
 PERFORM "Delete_From_Terminals"(mRec.id_terminals::text,);
END IF;
 RETURN NEXT mRec;
   end loop;
   return;
end;$BODY$
LANGUAGE plpgsql VOLATILE
COST 100
ROWS 1000;
ALTER FUNCTION "Delete_From_Terminals_Casc_final12"(bigint, bigint)
  OWNER TO postgres;

你的代码有两个问题,如果我没看错的话:

  1. 您正在使用 INNER JOIN 加入 mobgroupdata。这将只检索所有表中确实存在的行的结果。请改用 LEFT OUTER JOIN
  2. 您尝试了 mRec.id != 0,但您正在寻找 NULL,而不是 00NULL 在 SQL 中不是一回事。你要的条件是mRec.id IS NOT NULL.