向oracle数据库中插入数据时,先判断插入数据是否重复,如果重复,通过sql提示重新输入,否则直接插入

RT上边已经描述的差不多了,主要实现的是判断和提示请高人赐教,不胜感激... RT
上边已经描述的差不多了,主要实现的是判断和提示
请高人赐教,不胜感激
展开
 我来答
zhuqibs
推荐于2018-05-07 · TA获得超过100个赞
知道小有建树答主
回答量:180
采纳率:0%
帮助的人:97.4万
展开全部
过去处理过这样的sql题目,由于数据量特别大,不好处理。

plsql程序很简单,关键是如果查询重复数据的方法,如果处理不好的话,程序运行非常缓慢。

建议,修改表的结构,对一行的数据对所有数据做一个校验值,象raid5一样,这样就可以加快查询速度了,但会降低插入速度,不过速度还是有提升的
随o天
2012-08-25 · TA获得超过3158个赞
知道大有可为答主
回答量:1740
采纳率:71%
帮助的人:2030万
展开全部
declare
i int;
begin
:
select count(*) into i from 表 where 关键字段=新值;
if i=0 then insert into 表... ...;
else 返回重新输入;
end if;
:
end;
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
老师小乔
2012-08-26 · TA获得超过3680个赞
知道大有可为答主
回答量:1985
采纳率:66%
帮助的人:696万
展开全部
这样的话是想用存储过程呢还是用触发器呢?
功能语句块:
begin
if exists (select biao.x from biao,new where biao.x=new.x)
提示重新输入
else
提交事务
end
相类似的功能我的习惯是在应用程序当中进行控制,会比这样写sql简单的多。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友2a25c78
2012-09-04
知道答主
回答量:32
采纳率:0%
帮助的人:8.4万
展开全部
begin
if exists (select 1 from table where biao.x=&d)
提示重新输入
else
提交事务
end
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式