网管联盟 | 网管论坛 | 网管u家 | 网管博客 | 网管软件 | 网管求职 | 小游戏 | 网管搜索 | 网管原创 | 网管聚合 | 网管读摘 | 网管焦点 | 世界素材 | 会员投稿 | 会员中心 
中国网管联盟
Windows Linux Cisco 网络技术 数据库 黑客攻防 DotNet Java PHP 认证 新闻资讯 服务器 存储资讯 网络设备 网管学堂 技术专题 焦点 网吧频道
 当前位置: > bitsCN.com > 数据库技术 > Oracle > 体系架构 > 注意:Oracle中的联合主键查询问题  

注意:Oracle中的联合主键查询问题

2006-10-01  作者:网管整理  来源:bitsCN.com  点评 投稿 收藏

  最近要进行导数的工作,从好几张表中导入到一张表,其中数据可能重复,所以在导入之前要进行数据的比对。 网管有家bitscn.net

  方法一:我用group by having count(*)>1将重复的数据提取出来,然后进行人工比对,事实证明,有够笨的!

中国网管论坛bbs.bitsCN.com

  方法二:请教了一位资深人员,提供了一个更好的方法。就是将三个字段连接起来作为主键,进行数据是否重复的判断。这里值得注意的是某列的值可能为空,所以要赋一个空字符串过去。

网管论坛bbs_bitsCN_com

select * from t1 where  nvl(col1,'')|| nvl(col2,'')|
| col3 not in (select col1||col2||col3  from t2)

网管有家www.bitscn.net

  然后将不重复的值,插入t2就可以了。

网管论坛bbs_bitsCN_com

TAGs   问题   查询   联合   注意   重复   数据   方法   比对   col2      
 上一篇:Oracle 10gR2中用正则表达式搜索文本   下一篇:Oracle中审计参数audit_trail的讨论
注意:Oracle中的联合主键查询问题 评论:
loading.. 评论加载中…
评论:请自觉遵守互联网相关政策法规,评论不得超过250字。

验证码: 注册用户
本类热门排行:
最新推荐文章:
网管论坛交流: