首页 | 资讯动态 | linux基础 | 系统管理 | 网络管理 | 编程开发 | linux数据库 | 服务器技术 | linux相关 | linux认证 | 嵌入式 | 下载中心 | 专题 | linux招聘 | 镜像站
OKLinux中文技术站
·设为首页
·加入收藏
·联系我们
系统管理: 中文环境 系统管理 桌面应用 内核技术 | Linux基础: 基础入门 安装配置 常用命令 经验技巧 软件应用 | Linux数据库: Mysql Postgre Oracle DB2 Sybase other
网络管理: 网络安全 网络应用 Linux服务器 环境配置 黑客安全 | 编程开发: PHP CC++ Python Perl Shell 嵌入式开发 java jsp | PHP技术: PHP基础 PHP技巧 PHP应用 PHP文摘
Linux资讯 Linux招聘 Linux专题 Apache | Linux相关: 硬件相关 Linux解决方案 Linux认证 企业应用 其它Unix | 相关下载: 资料下载 参考手册 开发工具 服务器类 软路由 其它
 技术搜索:
会员中心 注册会员 高级搜索  
  → 当前位置:首页>linux数据库>oracle>正文

在不同情况下判断是否存在记录的实用方法

http://www.oklinux.cn  2007-11-28  来源: 赛迪网 61913  会员收藏  游客收藏  【 】 

很多网友在判定是否存在记录时经常使用下面的方法:

select count(*) into t_count from t where condition;
if t_count> 0 then ....

但上面的方法的不足之处主要在于:某些情况下我们需要的仅仅是是否存在,而不是得到总记录数。查询记录总数付出了不必要的性能代价。

下面我们具体来看两种情况:

1. 假如判定是否存在记录后, 要查询记录中的某些列的信息,或者是决定要对表进行insert/update操作,具体操作:

(1)

select count(*) into t_count from t where condition;
if t_count> 0 then 
   select cols into t_cols from t where condition;
else
   otherstatement;
end;

(2)

select count(*) into t_count from t where condition;
if t_count> 0 then 
  update ...;
else
  insert ...;
end;

注释:以上两种操作,都可以采用直接操作,然后进行例外处理的方式,根本就不进行这个存在性判定。

改写后的(1)

begin
  select cols into t_cols from t where condition;
exception 
  when no_data_found then begin 
    statement-block2;
  end;
  when others then begin
    raise error...
  end;
end;

改写后的(2)

update t set ... where condition;
IF SQL%NOTFOUND THEN
  insert into t ...
END IF;

或者:

begin
  insert into t ...
exception 
  when DUP_VAL_ON_INDEX then begin 
    update t set ...
  end;
end;

2. 假如判定是否存在记录来决定是否进行其它操作, 如下例

select count(*) into t_count from t where condition;
if t_count> 0 then ....

则可以改成这样的语句:

select count(*) into t_count from dual where exists
(select 1 from t where condition);
if t_count> 0 then ....

假如我们使用改写后的语句,绝大多数情况下应该会有比原来的语句又更好的性能。


上一篇:服务器出现TEMP表空间极限扩大的解决方法   下一篇:日志表及触发器脚本生成器的实例参考脚本


收藏于收藏夹】 【评论】 【推荐】 【打印】 【关闭
相关文档
·服务器出现TEMP表空间极限扩大的解决方法
·日志表及触发器脚本生成器的实例参考脚本
·Oracle 10g批量绑定forall bulk collect
·如何在"procedure"中完成对结果集的查询
·示例:Oracle数据库分区压缩的物化视图MV
·教你快速掌握清内存对象及转储的实用命令
·教你轻松掌握如何使用"RMAN"复制数据库
·比较两个schema业务数据的相同于不同之处
·用简单的方法实现Oracle测试库更改用户名
·教你快速掌握基于“等待事件”的性能诊断
·带你轻松接触一些比较常用的sql*plus命令
·轻松掌握如何从sql*plus向shell传递变量
·怎样有条件的分步删除数据表中的记录
·实例讲解如何才能重建"UNDO TABLESPACE"
·告别过往的一头雾水 掌握card的标准含义
·_small_table_threshold定义大小表的界限
发表评论
密码: 匿名评论
评论内容:

(不超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规)
 
  最新文档
·讲解Oracle移动数据文件到新分区的过程
·如何使用Ruby脚本调用Oracle存储过程
·哪些因素可以影响Oracle数据库的性能
·带你深入了解Oracle数据库的进制转换
·讲解V$Datafile_Header相关字段的使用
·探讨基于不绑定变量与绑定变量的柱状图
·pl/sql developer中TIMESTAMP的显示格
·教你快速掌握如何使用"Opatch"打补丁
·如何调整"Oracle"数据库服务器的性能
·视图上含有row_number分析函数没法走索
·Linux自动备份MySQL数据库的实用方法
·如何更改rac的vip地址和集群互联地址
  阅读排行
·如何修改遗失的MySQL的ROOT用户密码
·详解远程SHELL下安装配置RedHat ES 5的
·教你如何将MySQL数据库的密码恢复
·教你在MySQL从口令恢复设置的密码
·在 Oracle Enterprise Linux 上升级到
·oracle9i installation on fedora core
·Oracle Instant client介绍
·Oracle高级复制(同步复制)配置步骤详细
·用Oracle归档日志进行恢复的方法
·Linux下的Oracle数据库编程详解
·Linux下Oracle9i RMAN备份及恢复步骤介
·带你轻松接触一些比较常用的sql*plus命
·Oracle的快照复制
·Oracle HA 在Unix上双机环境的安装指南
·Oracle 数据库存储结构简介
网摘收藏: