我用的是oracle11g,现在有以下需求:向一个表中插入某条数据前,先判断,如果该数据存在则执行更新操作,若不存在执行插入操作,谁知道sql语句怎么写呢 :cry:
5条回答 默认 最新
- iteye_8576 2011-10-10 15:26关注
方法很多,建议merge。写个plsql的:
[code="sql"]
DECLARE
v_id VARCHAR2(100);
v_sort_id VARCHAR2(100);
v_data VARCHAR2(100);
BEGIN
BEGIN
v_id := '1';
v_sort_id := '1';
v_data := '1';
INSERT INTO T(t.id,t.sort_id,t.t_data) VALUES (v_id,v_sort_id,v_data);
dbms_output.put_line('insert');
EXCEPTION
-- 主键重复更新
WHEN DUP_VAL_ON_INDEX THEN
UPDATE T SET sort_id = v_sort_id,t_data = v_data WHERE id = v_id;
dbms_output.put_line('update');
END;
COMMIT
EXCEPTION
WHEN OTHERS THEN
ROLLBACK;
dbms_output.put_line('error!!!');
END;
[/code]本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 多电路系统共用电源的串扰问题
- ¥15 slam rangenet++配置
- ¥15 有没有研究水声通信方面的帮我改俩matlab代码
- ¥15 对于相关问题的求解与代码
- ¥15 ubuntu子系统密码忘记
- ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
- ¥15 保护模式-系统加载-段寄存器
- ¥15 电脑桌面设定一个区域禁止鼠标操作
- ¥15 求NPF226060磁芯的详细资料
- ¥15 使用R语言marginaleffects包进行边际效应图绘制