项目场景:
提示:这里简述项目相关背景:
例如:有时需要根据delete的id,进行别的表的update
问题描述
提示:但是postgre不允许delete 作为update的子语句
例如: update a set field=xxx where id =( delete from b returning id);
@Override
public void run() {
bytes = mmInStream.read(buffer);
mHandler.obtainMessage(READ_DATA, bytes, -1, buffer).sendToTarget();
}
原因分析:
提示:这里填写问题的分析:阿斯
例如:Handler
发送消息有两种方式,分别是 Handler.obtainMessage()
和 Handler.sendMessage()
,其中 obtainMessage
方式当数据量过大时,由于 MessageQuene
大小也有限,所以当 message
处理不及时时,会造成先传的数据被覆盖,进而导致数据丢失。
解决方案:
提示:以下是用with实现的
WITH t1 AS (delete from rule_draft
where draft_id = 130678321152 returning dqc_rule_id)
update rule r
set
rule_status_cd = 'complete',
modify_tm = now()
from t1
where
r.dqc_rule_id = t1.dqc_rule_id