Oracle中怎么利用row_number()over()方式解决插入数据时重复键
发表于:2025-12-03 作者:千家信息网编辑
千家信息网最后更新 2025年12月03日,本篇文章为大家展示了Oracle中怎么利用row_number()over()方式解决插入数据时重复键,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。导入目的表
千家信息网最后更新 2025年12月03日Oracle中怎么利用row_number()over()方式解决插入数据时重复键
本篇文章为大家展示了Oracle中怎么利用row_number()over()方式解决插入数据时重复键,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
导入目的表


上图中可以看到,我们的目的表中的主键有三个orgcode,saleno和serialno
源表
源表还是我们SQL数据库里的表
从两个数据表中可以看到部分列需要我们自己对应的,而源表中并没有serialno这一项,通过表分析我们可以看出,如果说源表的数据中同一个SaleNo中如果有两个ZfCode,我们如果把Serialno设置为一个默认值 ,肯定会变为插入重复键了。
我们执行一下默认的插入语句,系统直接弹出重复键的问题
我们看了一下数据中SaleNo的2019040100015486中有两条数据,按我们要导入的表的主键orgcode,Saleno,Serialno,这样插入肯定是重复键了
解决上面这个问题我们就用到了row_number()over()的函数
通过我们把Saleno进行分组排序,修改一下查询的数据
可以看到同一SaleNo下的两条数据自动排序了。
完整的插入代码
insert into tSalSalePay201904(Orgcode,Saleno,Trantype,Serialno,Zfcode,Zfname, Zfno,Paysstotal,Zftotal,Sstotal,Jzdate) select '0' as orgcode,"SaleNo","TranType", row_number() over(partition by "SaleNo" order by "SaleNo") as Serialno, "ZfCode","ZfName","ZfNo","ZfTotal","ZfTotal","ZfTotal","JzDate" from tJkSalePay201904@Odbc_Sql src where not exists(select * from tSalSalePay201904 dst where dst.Orgcode='0' and dst.Saleno=src."SaleNo")
基本上row_number() over()这个函数主要用在各种数据统计的sql中,感觉比group by好用的都,可以在一个查询中对多列数据进行分组,尤其在多表关联查询中,row_number() over()还是非常便捷的。
上述内容就是Oracle中怎么利用row_number()over()方式解决插入数据时重复键,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注行业资讯频道。
数据
查询
方式
两个
内容
函数
技能
目的
知识
还是
问题
分组
排序
肯定
便捷
简明
简明扼要
三个
上图
代码
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
软件开发计税规定
钢铁厂数据库招聘
公司提供数据库
服务器上架费用
云服务器 上市公司
保山互联网科技贵不贵
小学生网络安全竞赛试题
江阴计算机网络技术供应
网络安全的真实案例额
bs软件开发公司 官网
达芬奇软件提示数据库不兼容
网络安全基础设施等级
上海车士友网络技术有限公司
企业教学软件开发
我的世界服务器简易抽奖机教程
互联网科技百创
杭州大擎棋牌软件开发公司
数据库临界资源
软件开发单一来源采购论证
河南省网络安全宣传周校园启动
游戏服务器显示连接失败
工程技术维普数据库
江苏综合软件开发质量保障
北京华为服务器维修价格
ev3用什么么软件开发的
免费化合物数据库
根据什么对网络安全事件分级
为什么网络安全是重大的战略问题
有趣的数据库发展史
珠海通信软件开发价格比较