首页
论坛
门户
空间
手机版
IXPUB
插件
收藏
设置
注册
登录
商店
搜索
培训
Wiki
Blog
归档
丛书
退出
ITPUB论坛
»
Oracle开发
» 请帮忙分析这个函数错在哪里?
‹‹ 上一主题
|
下一主题 ››
12
1/2
1
2
››
投票
交易
悬赏
活动
评价
|
打印
|
推荐
|
订阅
|
收藏
标题:
[PL/SQL]
请帮忙分析这个函数错在哪里?
hotiice
版主
精华贴数 10
个人空间
0
技术积分 16884 (62)
社区积分 1803 (662)
注册日期 2004-9-9
论坛徽章:21
#1
使用道具
发表于 2008-9-17 15:28
请帮忙分析这个函数错在哪里?
--分步插入
create or replace procedure inserttab1(rowc NUMBER,colc NUMBER)
is
buf varchar(24000):='insert into tcol'||to_char(colc)||' select level,';
begin
if rowc<=1000 then
for i in 1..colc-1
loop
buf:=buf||'mod(level*DBMS_RANDOM.RANDOM,1e10),';
end loop;
buf:=buf||'mod(level*DBMS_RANDOM.RANDOM,1e10) from dual connect by level<='||to_char(rowc);
execute immediate buf;
commit;
else
for j in 1..rowc/1000+1
loop
buf :='insert into tcol'||to_char(colc)||' select level+'||(j-1)*1000||',';
for i in 1..colc-1
loop
buf:=buf||'mod(level*DBMS_RANDOM.RANDOM,1e10),';
end loop;
if j<rowc/1000 then
buf:=buf||'mod(level*DBMS_RANDOM.RANDOM,1e10) from dual connect by level<='||to_char(1000);
else
buf:=buf||'mod(level*DBMS_RANDOM.RANDOM,1e10) from dual connect by level<='||to_char(rowc-j*1000);
end if;
execute immediate buf;
commit;
end loop;
end if;
end;
想用来代替
-- inserttab插入一个含有指定数值型列的表,插入的行数可以指定,数值是随机的
create or replace procedure inserttab(rowc NUMBER,colc NUMBER)
is
buf varchar(24000):='insert into tcol'||to_char(colc)||' select level,';
begin
for i in 1..colc-1
loop
buf:=buf||'mod(level*DBMS_RANDOM.RANDOM,1e10),';
end loop;
buf:=buf||'mod(level*DBMS_RANDOM.RANDOM,1e10) from dual connect by level<='||to_char(rowc);
execute immediate buf;
end;
但是插入的行数不对
SQL> exec inserttab1(20000,50);
PL/SQL procedure successfully completed.
Elapsed: 00:00:13.07
SQL> select count(*) from tcol50;
COUNT(*)
----------
19002
Elapsed: 00:00:00.03
用
create or replace procedure createtab(colc IN NUMBER,PP IN NUMBER:=15,SS IN NUMBER:=2)
is
buf varchar(24000):='create table tcol'||to_char(colc)||'(x1 varchar(10),';
begin
for i in 1..colc-1
loop
buf:=buf||'v'||to_char(i)||' number('||to_char(PP)||','||to_char(SS)||'),';
end loop;
buf:=buf||'v'||to_char(colc)||' number('||to_char(PP)||','||to_char(SS)||'))';
execute immediate buf;
end;
建立表
__________________
①②⑧
只看该作者
hotiice
版主
精华贴数 10
个人空间
0
技术积分 16884 (62)
社区积分 1803 (662)
注册日期 2004-9-9
论坛徽章:21
#2
使用道具
发表于 2008-9-17 16:05
自己改好了
create or replace procedure inserttab1(rowc NUMBER,colc NUMBER)
is
buf varchar(24000):='insert into tcol'||to_char(colc)||' select level,';
b number:=floor(rowc/1000);
begin
if rowc<=1000 then
for i in 1..colc-1
loop
buf:=buf||'mod(level*DBMS_RANDOM.RANDOM,1e10),';
end loop;
buf:=buf||'mod(level*DBMS_RANDOM.RANDOM,1e10) from dual connect by level<='||to_char(rowc);
execute immediate buf;
commit;
else
for j in 1..b
loop
buf :='insert into tcol'||to_char(colc)||' select level+'||(j-1)*1000||',';
for i in 1..colc-1
loop
buf:=buf||'mod(level*DBMS_RANDOM.RANDOM,1e10),';
end loop;
buf:=buf||'mod(level*DBMS_RANDOM.RANDOM,1e10) from dual connect by level<='||to_char(1000);
execute immediate buf;
commit;
end loop;
if rowc-b*1000>0 then
buf :='insert into tcol'||to_char(colc)||' select level+'||(b)*1000||',';
for i in 1..colc-1
loop
buf:=buf||'mod(level*DBMS_RANDOM.RANDOM,1e10),';
end loop;
buf:=buf||'mod(level*DBMS_RANDOM.RANDOM,1e10) from dual connect by level<='||to_char(rowc-b*1000);
execute immediate buf;
commit;
end if;
end if;
end;
__________________
①②⑧
只看该作者
hotiice
版主
精华贴数 10
个人空间
0
技术积分 16884 (62)
社区积分 1803 (662)
注册日期 2004-9-9
论坛徽章:21
#3
使用道具
发表于 2008-9-17 16:16
改得短了一点
create or replace procedure inserttab1(rowc NUMBER,colc NUMBER)
is
bufl varchar(24000):='insert into tcol'||to_char(colc)||' select level,';
buf varchar(24000):='';
bufr varchar(24000):='';
b number:=floor(rowc/1000);
begin
for i in 1..colc-1
loop
buf:=buf||'mod(level*DBMS_RANDOM.RANDOM,1e10),';
end loop;
if rowc<=1000 then
bufr:='mod(level*DBMS_RANDOM.RANDOM,1e10) from dual connect by level<='||to_char(rowc);
execute immediate bufl||buf||bufr;
commit;
else
for j in 1..b
loop
bufl:='insert into tcol'||to_char(colc)||' select level+'||(j-1)*1000||',';
bufr:='mod(level*DBMS_RANDOM.RANDOM,1e10) from dual connect by level<='||to_char(1000);
execute immediate bufl||buf||bufr;
commit;
end loop;
if rowc-b*1000>0 then
bufl :='insert into tcol'||to_char(colc)||' select level+'||(b)*1000||',';
bufr:='mod(level*DBMS_RANDOM.RANDOM,1e10) from dual connect by level<='||to_char(rowc-b*1000);
execute immediate bufl||buf||bufr;
commit;
end if;
end if;
end;
__________________
①②⑧
只看该作者
jack198409
中级会员
来自 湖北武汉
精华贴数 0
个人空间
484
技术积分 3219 (476)
社区积分 3467 (416)
注册日期 2007-8-10
论坛徽章:35
#4
使用道具
发表于 2008-9-17 16:27
报什么错?
__________________
金麟岂是池中物,一遇风云便化龙!
我的SPACE空间欢迎您!
只看该作者
阿日
2M-Never give up
精华贴数 0
个人空间
501
技术积分 1787 (945)
社区积分 1155 (896)
注册日期 2004-1-4
论坛徽章:22
#5
使用道具
发表于 2008-9-17 16:39
呵,版主已经改好了呀
__________________
我欲将心向明月,奈何明月照沟渠.
过去的都过去了,大不了从头再来,别回头,向前看!
http://blog.csdn.net/zxf_feng
只看该作者
hotiice
版主
精华贴数 10
个人空间
0
技术积分 16884 (62)
社区积分 1803 (662)
注册日期 2004-9-9
论坛徽章:21
#6
使用道具
发表于 2008-9-17 16:41
教训
insert into a select level from dual connect vy level<=-1也会插入
__________________
①②⑧
只看该作者
nyfor
Oracle Fan
来自 苏州
精华贴数 7
个人空间
0
技术积分 8319 (155)
社区积分 475 (1610)
注册日期 2002-1-6
论坛徽章:17
#7
使用道具
发表于 2008-9-17 16:43
QUOTE:
原帖由
jack198409
于 2008-9-17 16:27 发表
报什么错?
2# 说已经改好了, 俺就不看了
__________________
帮助别人,也在帮助自己!
Oracle Version 9.2.0
Oracle Version 10.2.0
看别人不顺眼是自己修养不够!
只看该作者
nyfor
Oracle Fan
来自 苏州
精华贴数 7
个人空间
0
技术积分 8319 (155)
社区积分 475 (1610)
注册日期 2002-1-6
论坛徽章:17
#8
使用道具
发表于 2008-9-17 16:45
select level from dual connect vy level<=-1
其实这样的查询我不太喜欢用, 只是最近看大家用得多了, 我偶尔也会用用
不过这样的insert 也能插入记录, 是比较奇怪, 该死的 Oracle
__________________
帮助别人,也在帮助自己!
Oracle Version 9.2.0
Oracle Version 10.2.0
看别人不顺眼是自己修养不够!
只看该作者
smallnavy
平常心
精华贴数 1
个人空间
3
技术积分 2407 (664)
社区积分 3478 (409)
注册日期 2003-9-2
论坛徽章:55
#9
使用道具
发表于 2008-9-17 17:01
QUOTE:
原帖由
hotiice
于 2008-9-17 16:41 发表
教训
insert into a select level from dual connect vy level
这个不容易注意。
__________________
竹仗芒鞋轻胜马,一蓑烟雨任平生
只看该作者
newkid
资深新手
老程序员
来自 银河系
精华贴数 2
个人空间
0
技术积分 2756 (579)
社区积分 0 (121048)
注册日期 2004-6-26
论坛徽章:5
#10
使用道具
发表于 2008-9-17 22:57
QUOTE:
原帖由
nyfor
于 2008-9-17 16:45 发表
select level from dual connect vy level
不奇怪也不该死
start with 限制第一层;
connect by 从第二层开始起作用;
where 对整个结果集过滤。
__________________
只看该作者
12
1/2
1
2
››
投票
交易
悬赏
活动
相关内容
ITPUB论坛
≡ 数据库技术 ≡
> Oracle数据库管理
> Oracle开发
> Oracle Developer Suite
> Oracle入门与认证
> Oracle专题深入讨论
> Oracle新技术/11g
> Oracle电子文档
> Oracle Fusion中间件
> IBM数据库产品
> MS SQL Server
> Sybase管理与开发
> MySQL及其它开源数据库
> 内存数据库
> 数据仓库与数据挖掘
> 移动及嵌入式数据库
≡ 企业信息化 ≡
> ERP产品与实践
> CRM产品与实践
> HR产品与实践
> 物流
> 供应链
> 供应链建模与仿真
> 物流设备与系统工程
> 企业管理咨询
> 管理协同与办公自动化
> IT服务管理
> 数据中心建设
> ERP二次开发
> Oracle ERP
> Oracle EBS R12
> PeopleSoft与JDE
> EBS相关文档
> 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号
联系我们
法律顾问
控制面板首页
编辑个人资料
积分交易
公众用户组
好友列表
升级个人空间
基本概况
论坛排行
主题排行
发帖排行
积分排行
在线时间
管理团队
管理统计