我用的是oracle11g,现在有以下需求:向一个表中插入某条数据前,先判断,如果该数据存在则执行更新操作,若不存在执行插入操作,谁知道sql语句怎么写呢 :cry:
方法很多,建议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]
肯定有判断数据唯一的,
那只能先查询出来判断了,假如有,那么把值替换过去更新,没有再插入。
用约束来做肯定是不好的。
用存储过程或者直接用程序控制。
1条sql实现就得使用MERGE INTO,为啥不用呢?
如果数据有唯一条件确定是否存在,大概可以这样子(pl/sql):
declare v number(10,0);
begin
select count(*) into v from tabname where key=xxxx;
if (v = 0 or v is null) then
--insert
else
--updae
end if;
end;