查看: 12547|回复: 50

[PRO*C] 关于10000个in 的解决办法

[复制链接]
论坛徽章:
14
2009新春纪念徽章
日期:2009-01-04 14:52:28沸羊羊
日期:2015-03-04 14:51:52优秀写手
日期:2014-03-14 06:00:13马上有房
日期:2014-02-18 16:42:022014年新春福章
日期:2014-02-18 16:42:022013年新春福章
日期:2013-02-25 14:51:24ITPUB 11周年纪念徽章
日期:2012-10-09 18:08:15蜘蛛蛋
日期:2012-06-27 21:08:142012新春纪念徽章
日期:2012-01-04 11:53:29ITPUB十周年纪念徽章
日期:2011-11-01 16:23:26
跳转到指定楼层
1#
发表于 2015-9-15 18:42 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 yulihua49 于 2015-9-17 20:33 编辑

我们需要:
select * from  table  where  some_col in (x,y,z......10000 个 在OCI,使用:
select * from table where some_col=:1
然后绑定10000个值。看起来很美,可惜不行。
下边的语句: 你把条件值和返回值都绑定成数组,条件是主键的全集。
update table set col1=col1 where some_col = :1 returning rowid into :2

具体需求见12楼。
论坛徽章:
8
玉兔
日期:2015-11-16 10:18:00铁扇公主
日期:2015-10-27 21:47:42九尾狐狸
日期:2015-12-11 22:31:15
2#
发表于 2015-9-15 18:48 | 只看该作者
先把这10000个值插入到一个临时表中

使用道具 举报

回复
论坛徽章:
14
2009新春纪念徽章
日期:2009-01-04 14:52:28沸羊羊
日期:2015-03-04 14:51:52优秀写手
日期:2014-03-14 06:00:13马上有房
日期:2014-02-18 16:42:022014年新春福章
日期:2014-02-18 16:42:022013年新春福章
日期:2013-02-25 14:51:24ITPUB 11周年纪念徽章
日期:2012-10-09 18:08:15蜘蛛蛋
日期:2012-06-27 21:08:142012新春纪念徽章
日期:2012-01-04 11:53:29ITPUB十周年纪念徽章
日期:2011-11-01 16:23:26
3#
 楼主| 发表于 2015-9-15 18:55 | 只看该作者
本帖最后由 yulihua49 于 2015-9-15 19:04 编辑
lugionline 发表于 2015-9-15 18:48
先把这10000个值插入到一个临时表中
慢死了,此方案被否决。而且多线程并行,无法操作。还是看我的答案吧!
update是虚的,要的是returning,条件集必须主键,10000个主键值。
确保每个条件返回不多于一个值。
最好返回值包含一个ROWID,好知道哪条有返回,哪条没有。

走路撞了电线杆,想起这么个办法,明天试试去。

使用道具 举报

回复
论坛徽章:
14
2009新春纪念徽章
日期:2009-01-04 14:52:28沸羊羊
日期:2015-03-04 14:51:52优秀写手
日期:2014-03-14 06:00:13马上有房
日期:2014-02-18 16:42:022014年新春福章
日期:2014-02-18 16:42:022013年新春福章
日期:2013-02-25 14:51:24ITPUB 11周年纪念徽章
日期:2012-10-09 18:08:15蜘蛛蛋
日期:2012-06-27 21:08:142012新春纪念徽章
日期:2012-01-04 11:53:29ITPUB十周年纪念徽章
日期:2011-11-01 16:23:26
4#
 楼主| 发表于 2015-9-15 19:23 | 只看该作者
yulihua49 发表于 2015-9-15 18:55
慢死了,此方案被否决。而且多线程并行,无法操作。还是看我的答案吧!
update是虚的,要的是returning, ...

ORACLE返回多行的returning并不实用。它要求你事先分配结果集,可是我事先并不知道能够返回多少行。

使用道具 举报

回复
论坛徽章:
407
紫蛋头
日期:2012-05-21 10:19:41迷宫蛋
日期:2012-06-06 16:02:49奥运会纪念徽章:足球
日期:2012-06-29 15:30:06奥运会纪念徽章:排球
日期:2012-07-10 21:24:24鲜花蛋
日期:2012-07-16 15:24:59奥运会纪念徽章:拳击
日期:2012-08-07 10:54:50奥运会纪念徽章:羽毛球
日期:2012-08-21 15:55:33奥运会纪念徽章:蹦床
日期:2012-08-21 21:09:51奥运会纪念徽章:篮球
日期:2012-08-24 10:29:11奥运会纪念徽章:体操
日期:2012-09-07 16:40:00
5#
发表于 2015-9-15 20:29 来自手机 | 只看该作者
Meikandong

使用道具 举报

回复
论坛徽章:
14
2009新春纪念徽章
日期:2009-01-04 14:52:28沸羊羊
日期:2015-03-04 14:51:52优秀写手
日期:2014-03-14 06:00:13马上有房
日期:2014-02-18 16:42:022014年新春福章
日期:2014-02-18 16:42:022013年新春福章
日期:2013-02-25 14:51:24ITPUB 11周年纪念徽章
日期:2012-10-09 18:08:15蜘蛛蛋
日期:2012-06-27 21:08:142012新春纪念徽章
日期:2012-01-04 11:53:29ITPUB十周年纪念徽章
日期:2011-11-01 16:23:26
6#
 楼主| 发表于 2015-9-15 20:33 | 只看该作者
本帖最后由 yulihua49 于 2015-9-15 20:34 编辑
〇〇 发表于 2015-9-15 20:29
Meikandong
假update,真returning。这样,条件集和结果集都能绑定数组。

使用道具 举报

回复
论坛徽章:
519
奥运会纪念徽章:垒球
日期:2008-09-15 01:28:12生肖徽章2007版:鸡
日期:2008-11-17 23:40:58生肖徽章2007版:马
日期:2008-11-18 05:09:48数据库板块每日发贴之星
日期:2008-11-29 01:01:02数据库板块每日发贴之星
日期:2008-12-05 01:01:03生肖徽章2007版:虎
日期:2008-12-10 07:47:462009新春纪念徽章
日期:2009-01-04 14:52:28数据库板块每日发贴之星
日期:2009-02-08 01:01:03生肖徽章2007版:蛇
日期:2009-03-09 22:18:532009日食纪念
日期:2009-07-22 09:30:00
7#
发表于 2015-9-15 22:02 | 只看该作者
首先,10000个值哪里来的?如果是查询出来的,那么就没必要先拿出来再塞回去。
假定10000个值全部来自客户,那么用临时表,或者嵌套表也好过IN LIST。嵌套表相当于数组,用TABLE()转换成集合来访问。
假UPDATE会生成REDO, UNDO等等不必要的开销。

使用道具 举报

回复
论坛徽章:
4
2012新春纪念徽章
日期:2012-01-04 11:58:18鲜花蛋
日期:2012-03-12 15:51:272015年新春福章
日期:2015-03-04 14:53:162015年新春福章
日期:2015-03-06 11:58:39
8#
发表于 2015-9-16 08:49 | 只看该作者
为什么要update returning 你想要的列 into 绑定变量,你值是已知的,写个循环直接赋值给绑定变量不行么?

使用道具 举报

回复
论坛徽章:
1088
金色在线徽章
日期:2007-04-25 04:02:08金色在线徽章
日期:2007-06-29 04:02:43金色在线徽章
日期:2007-03-11 04:02:02在线时间
日期:2007-04-11 04:01:02在线时间
日期:2007-04-12 04:01:02在线时间
日期:2007-03-07 04:01:022008版在线时间
日期:2010-05-01 00:01:152008版在线时间
日期:2011-05-01 00:01:342008版在线时间
日期:2008-06-03 11:59:43ITPUB年度最佳技术原创精华奖
日期:2013-03-22 13:18:30
9#
发表于 2015-9-16 11:34 | 只看该作者
用table函数。。。

使用道具 举报

回复
招聘 : 数据库开发
论坛徽章:
29
秀才
日期:2015-12-14 14:47:54秀才
日期:2015-11-12 17:43:40秀才
日期:2015-11-11 10:22:49秀才
日期:2015-11-11 09:58:34秀才
日期:2015-10-26 09:24:12秀才
日期:2015-09-21 11:16:42秀才
日期:2015-12-14 14:51:16秀才
日期:2015-12-14 14:56:09秀才
日期:2015-11-23 09:48:22ITPUB14周年纪念章
日期:2015-10-26 17:23:44
10#
发表于 2015-9-16 14:18 | 只看该作者
本帖最后由 juan025 于 2015-9-16 14:19 编辑
newkid 发表于 2015-9-15 22:02
首先,10000个值哪里来的?如果是查询出来的,那么就没必要先拿出来再塞回去。
假定10000个值全部来自客户 ...
table貌似有个数限制
  1. Create or replace type type_du as table of Integer;
  2. select column_value as du_id from table(type_du(id_list))
复制代码
ID_LIST只能输入1000个,超过1000个就报错:函数参数值过多

使用道具 举报

回复

您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

TOP技术积分榜 社区积分榜 徽章 团队 统计 知识索引树 积分竞拍 文本模式 帮助
  ITPUB首页 | ITPUB论坛 | 数据库技术 | 企业信息化 | 开发技术 | 微软技术 | 软件工程与项目管理 | IBM技术园地 | 行业纵向讨论 | IT招聘 | IT文档
  ChinaUnix | ChinaUnix博客 | ChinaUnix论坛
CopyRight 1999-2011 itpub.net All Right Reserved. 北京盛拓优讯信息技术有限公司版权所有 联系我们 未成年人举报专区 
京ICP备16024965号-8  北京市公安局海淀分局网监中心备案编号:11010802021510 广播电视节目制作经营许可证:编号(京)字第1149号
  
快速回复 返回顶部 返回列表