首页
论坛
门户
空间
手机版
IXPUB
插件
收藏
设置
注册
登录
商店
搜索
培训
Wiki
Blog
归档
丛书
退出
ITPUB论坛
»
Oracle开发
» for v in ( *****) loop shape 问题
‹‹ 上一主题
|
下一主题 ››
17
1/2
1
2
››
投票
交易
悬赏
活动
评价
|
打印
|
推荐
|
订阅
|
收藏
标题: for v in ( *****) loop shape 问题
ekunge
中级会员
精华贴数 0
个人空间
0
技术积分 533 (3574)
社区积分 0 (414537)
注册日期 2005-5-19
论坛徽章:0
#1
使用道具
发表于 2008-6-30 14:55
for v in ( *****) loop shape 问题
在网上看到一个课程,看到一个用法,
declare
type newtype is table of demo.last_name%type INDEX BY BINARY_INTEGER;
shape newtype;
i number;
j number;
begin
dbms_output.put_line('beginforall:'||to_char(sysdate,'yyyy hh24:mi:ss'));
for v in (select rownum,last_name from emp) loop
shape(v.rownum):=v.last_name;
end loop;
select count(*) into i from emp;
forall j in 1..i
insert into demo
values(shape(j));
dbms_output.put_line('endforall'||to_char(sysdate,'yyyy hh24:mi:ss'));
end;
/
beginforall:2008 15:55:31
endforall2008 15:55:32
PL/SQL 过程已成功完成。
执行效率比
begin
dbms_output.put_line('begin:'||to_char(sysdate,'yyyy hh24:mi:ss'));
for v in (select * from emp) loop
insert into demo
values(v.last_name);
end loop;
dbms_output.put_line('end:'||to_char(sysdate,'yyyy hh24:mi:ss'));
end;
/
begin:2008 15:53:42
end:2008 15:53:51
PL/SQL 过程已成功完成。
这个要快。我自己试了,也确实是快。
但是,有个地方没有太理解。
for v in (select rownum,last_name from emp) loop
shape(v.rownum):=v.last_name;
end loop;
select count(*) into i from emp;
forall j in 1..i
insert into demo
values(shape(j));
1、这里的 shape(v.rownum):=v.last_name; 的意义是什么
2、如果我是要insert into table_1 (column1,column2),也就是说要插入多个字段的话,要如何来处理。
__________________
看贴长见识发贴求真知
只看该作者
sunfly1983
初级会员
精华贴数 0
个人空间
0
技术积分 736 (2539)
社区积分 372 (1628)
注册日期 2006-10-14
论坛徽章:4
#2
使用道具
发表于 2008-6-30 15:04
shape是个对象类型数组吧!
只看该作者
caizhuoyi
Oracle Stranger
精华贴数 2
个人空间
0
技术积分 1504 (1108)
社区积分 445 (1472)
注册日期 2006-3-1
论坛徽章:3
#3
使用道具
发表于 2008-6-30 15:13
回复 #1 ekunge 的帖子
1、这里的 shape(v.rownum):=v.last_name; 的意义是什么
index by table,是一个collection。
2、如果我是要insert into table_1 (column1,column2),也就是说要插入多个字段的话,要如何来处理。
声明:type newtype is table of demo%rowtype INDEX BY BINARY_INTEGER;
__________________
我不在江湖,但江湖中有我的传说;
我身在江湖,江湖里却没有我的传说。
只看该作者
wangfans
精华贴数 3
个人空间
20
技术积分 5395 (235)
社区积分 5666 (258)
注册日期 2006-11-29
论坛徽章:52
#4
使用道具
发表于 2008-6-30 15:24
怎么会前面那个快呢?多走了一步还快? 怪异~~
__________________
-------------------------------------------------
Life is always like this !
-------------------------------------------------
MSN: wangfans@163.com
-------------------------------------------------
只看该作者
飘渺一尘烟
初级会员
精华贴数 0
个人空间
0
技术积分 11 (80396)
社区积分 1 (38891)
注册日期 2005-8-30
论坛徽章:0
#5
使用道具
发表于 2008-6-30 15:37
forall 是批量方式,笔for loop这种方式快
只看该作者
visual2006
精华贴数 0
个人空间
0
技术积分 768 (2435)
社区积分 4 (18236)
注册日期 2006-7-23
论坛徽章:1
#6
使用道具
发表于 2008-6-30 15:40
集合操作比单个元素循环肯定快些。
只看该作者
ekunge
中级会员
精华贴数 0
个人空间
0
技术积分 533 (3574)
社区积分 0 (414537)
注册日期 2005-5-19
论坛徽章:0
#7
使用道具
发表于 2008-6-30 15:45
QUOTE:
原帖由
caizhuoyi
于 2008-6-30 15:13 发表
1、这里的 shape(v.rownum):=v.last_name; 的意义是什么
index by table,是一个collection。
2、如果我是要insert into table_1 (column1,column2),也就是说要插入多个字段的话,要如何来处理。
声明:type newtype is table of demo%rowtype INDEX BY BINARY_INTEGER;
不好意思,我对于这个1、这里的 shape(v.rownum):=v.last_name; 的意义是什么
index by table,是一个collection。 还是不太理解。
如果我是需要插入多个字段的话,这个地方要如何改。
前面改成 type newtype is table of demo%rowtype INDEX BY BINARY_INTEGER; [/quote]
这个我是知道的,但是 shape(v.rownum):=v.last_name 这句要如何改?
这个应该和最后面的那个 insert into demo values(shape(j)) 这里有关,
如果是多字段的话, 这2个地方分别要如何修改。
抱歉,对这块知识几乎完全不了解,但是希望能学习一下。
请高手赐教。
__________________
看贴长见识发贴求真知
只看该作者
wangfans
精华贴数 3
个人空间
20
技术积分 5395 (235)
社区积分 5666 (258)
注册日期 2006-11-29
论坛徽章:52
#8
使用道具
发表于 2008-6-30 15:45
呵呵,
看错了,我还以为一样呢
__________________
-------------------------------------------------
Life is always like this !
-------------------------------------------------
MSN: wangfans@163.com
-------------------------------------------------
只看该作者
mychary
高级会员
来自 合肥
精华贴数 0
个人空间
0
技术积分 6770 (180)
社区积分 158 (2635)
注册日期 2003-9-18
论坛徽章:9
#9
使用道具
发表于 2008-6-30 15:47
for v in (select rownum,last_name from emp) loop
for v in (select * from emp) loop
----游标的sql语句是不一样的。 可比性差了点
只看该作者
wangfans
精华贴数 3
个人空间
20
技术积分 5395 (235)
社区积分 5666 (258)
注册日期 2006-11-29
论坛徽章:52
#10
使用道具
发表于 2008-6-30 16:03
QUOTE:
原帖由
mychary
于 2008-6-30 15:47 发表
for v in (select rownum,last_name from emp) loop
for v in (select * from emp) loop
----游标的sql语句是不一样的。 可比性差了点
我觉得问题不在这里,是在FOR ALL上面
__________________
-------------------------------------------------
Life is always like this !
-------------------------------------------------
MSN: wangfans@163.com
-------------------------------------------------
只看该作者
17
1/2
1
2
››
投票
交易
悬赏
活动
相关内容
ITPUB论坛
≡ 数据库技术 ≡
> Oracle数据库管理
> Oracle开发
> Oracle Developer Suite
> Oracle入门与认证
> Oracle专题深入讨论
> Oracle新技术/11g
> Oracle电子文档
> Oracle Application Server套件
> IBM数据库产品
> MS SQL Server
> Sybase管理与开发
> MySQL及其它开源数据库
> 内存数据库
> 数据仓库与数据挖掘
> 移动及嵌入式数据库
≡ 企业信息化 ≡
> ERP产品与实践
> CRM产品与实践
> HR产品与实践
> 物流
> 供应链
> 供应链建模与仿真
> 物流设备与系统工程
> 企业管理咨询
> 管理协同与办公自动化
> IT服务管理
> 数据中心建设
> ERP二次开发
> Oracle ERP
> EBS相关文档
> PeopleSoft与JDE
> SAP R/3
> SAP Business One开发与快速实施
> SAP财务及CRM
> SAP后勤及HR
> mySAP ERP
> 系统开发及跨应用设置
> SAP相关文档
> 国外其它ERP产品
> 国内ERP产品
≡ 开发技术 ≡
> Java入门与认证版
> Java web开发及框架技术
> Java企业开发
> ASP.NET【已迁移到微软开发技术论坛】
> .Net企业开发与应用【已迁移到微软开发技术论坛】
> WEB程序开发
> WEB 2.0技术
> 动态语言
> 移动与游戏开发
≡ 系统设计与项目管理 ≡
> 系统分析与UML
> 系统分析与UML精华区
> 项目管理
> 项目过程
> 软件测试
> 算法讨论与研究
≡ IBM软件技术园地 ≡
> IBM数据库产品
> Lotus
> Tivoli
> Websphere
> Rational
> 与SOA相关的IBM产品与技术
> IBM软件技术精英协会
> 软件技术精英活动专版
≡ 操作系统与硬件 ≡
> AIX及IBM产品【已迁移到IXPUB】
> HP-UX及HP产品【已迁移到IXPUB】
> Solaris及SUN产品【已迁移到IXPUB】
> Linux及其应用 【已迁移到IXPUB】
> 其它UNIX系统【已迁移到IXPUB】
> windows系统及微软相关产品 【已迁移到IXPUB】
> 存储设备与容灾技术 【已迁移到IXPUB】
> 服务器 【已迁移到IXPUB】
≡ 行业纵向讨论区 ≡
> IT业界评论与展望
> 政府与教育事业
> 中国政府信息主管联盟
> 电信行业
> 金融行业
> 医卫行业
> 制造行业
> 电力行业
> 信息安全与审计
≡ 会员交流 ≡
> IT职业生涯
> 招聘求职商务信息
> 旅游,驴友
> 汽车世界
> 外语角
> 数码摄影
> 你的故事我的歌
> 音乐推荐区
> 电子图书与IT文档资料
> 软件交流
> 软件交流精华区
≡ ITPUB产品与服务 ≡
> ITPUB地面活动专版
> BLOG天地
> WIKI世界
> 授权用户区
> 站务管理
≡ 微软开发技术 ≡
> 开发工具和语言
> .NET Framework 相关
> Visual Basic/VB.net
> Visual C#
> Visual C++/vc.net
> Visual Studio
> .NET软件架构与模式
> .NET开发辅助工具及框架
> Web开发
> ASP.NET与AJAX
> Web相关技术讨论(IIS等)
> Silverlight 技术
> 微软企业级产品技术
> SQL Server
> windows server
> SharePoint
> Exchange Server
> Biztalk
> 嵌入式及移动开发
> Windows Embedded 嵌入式技术
> Windows 移动设备
> Office开发
> Microsoft office system
> Office Business Application
> 微软产品用户交流区
> .Net电子书籍&&书籍介绍
> .Net人才交流
技术积分榜
社区积分榜
徽章
电子杂志
会员
团队
统计
邮箱
游乐场
帮助
TOP
CopyRight 1999-2006 itpub.net All Right Reserved.
北京皓辰广域网络信息技术有限公司. 版权所有
E-mail:Webmaster@itpub.net
京ICP证:010037号
联系我们
法律顾问
控制面板首页
编辑个人资料
积分交易
公众用户组
好友列表
升级个人空间
基本概况
论坛排行
主题排行
发帖排行
积分排行
在线时间
管理团队
管理统计