• 售前

  • 售后

热门帖子
入门百科

在postgresql中竣事掉正在执行的SQL语句操作

[复制链接]
护身马甲上阵兜 显示全部楼层 发表于 2021-10-26 13:22:34 |阅读模式 打印 上一主题 下一主题
结束进程两种方式:
  1. SELECT pg_cancel_backend(PID)
复制代码
取消后台操纵,回滚未提交事物 (select);
  1. SELECT pg_terminate_backend(PID)
复制代码
停止session,回滚未提交事物(select、update、delete、drop);
  1. SELECT * FROM pg_stat_activity;
复制代码
根据datid=10841
  1. SELECT pg_terminate_backend (10841);
复制代码
增补:PostgreSQL无法在PL / pgSQL中开始/结束事件
我正在寻求澄清怎样确保plpgsql函数中的原子事件,以及为数据库进行此特定更改设置了隔离级别.
在下面显示的plpgsql函数中,我想确保BOTH的删除和插入乐成.当我实验将它们包装在一个事件中时,我收到一个错误:
错误:无法在PL / pgSQL中开始/结束事件.
假如另一个用户在此功能已删除自界说记录之后,但在此函数有时机插入自界说记录之前,为环境(RAIN,NIGHT,45MPH)添加了默认行为,下面的函数执行过程中会发生什么?是否有一个隐式事件包装插入和删除,以便假如另一个用户已经更改了此函数引用的任何一个行,两者都将回滚?我可以设置此功能的隔离级别吗?
  1. create function foo(v_weather varchar(10), v_timeofday varchar(10), v_speed varchar(10),
  2. v_behavior varchar(10))
  3. returns setof CUSTOMBEHAVIOR
  4. as $body$
  5. begin
  6. -- run-time error if either of these lines is un-commented
  7. -- start transaction ISOLATION LEVEL READ COMMITTED;
  8. -- or, alternatively, set transaction ISOLATION LEVEL READ COMMITTED;
  9.   delete from CUSTOMBEHAVIOR
  10.   where weather = 'RAIN' and timeofday = 'NIGHT' and speed= '45MPH' ;
  11. -- if there is no default behavior insert a custom behavior
  12. if not exists
  13.   (select id from DEFAULTBEHAVIOR where a = 'RAIN' and b = 'NIGHT' and c= '45MPH') then
  14.   insert into CUSTOMBEHAVIOR
  15.   (weather, timeofday, speed, behavior)
  16.   values
  17.   (v_weather, v_timeofday, v_speed, v_behavior);
  18. end if;
  19. return QUERY
  20. select * from CUSTOMBEHAVIOR where ... ;
  21. -- commit;
  22. end
  23. $body$
  24. LANGUAGE plpgsql
复制代码
一个plpgsql函数在事件中自动运行.这统统都乐成了,统统都失败了.
我引用the manual on plpgsql functions:
  1. Functions and trigger procedures are always executed within a transaction established by an outer query — they cannot start or commit that transaction, since there would be no context for them to execute in. However, a block containing an EXCEPTION clause effectively forms a subtransaction that can be rolled back without affecting the outer transaction.
复制代码
以是,假如你需要,你可以捕获理论上可能发生的非常(但是不大可能).
Details on trapping errors in the manual.
您的功能审查和简化:
  1. CREATE FUNCTION foo(v_weather text
  2.    , v_timeofday text
  3.    , v_speed text
  4.    , v_behavior text)
  5. RETURNS SETOF custombehavior AS
  6. $body$
  7. BEGIN
  8. DELETE FROM custombehavior
  9. WHERE weather = 'RAIN'
  10. AND timeofday = 'NIGHT'
  11. AND speed = '45MPH';
  12. INSERT INTO custombehavior (weather, timeofday, speed, behavior)
  13. SELECT v_weather, v_timeofday, v_speed, v_behavior
  14. WHERE NOT EXISTS (
  15. SELECT 1 FROM defaultbehavior
  16. WHERE a = 'RAIN'
  17. AND b = 'NIGHT'
  18. AND c = '45MPH'
  19. );
  20. RETURN QUERY
  21. SELECT * FROM custombehavior WHERE ... ;
  22. END
  23. $body$LANGUAGE plpgsql
复制代码
以上为个人经验,希望能给各人一个参考,也希望各人多多支持脚本之家。如有错误或未思量完全的地方,望不吝见教。

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作