首页
论坛
门户
空间
手机版
IXPUB
插件
收藏
设置
注册
登录
商店
搜索
培训
Wiki
Blog
归档
丛书
退出
ITPUB论坛
»
Oracle开发
» 动态查询求教
‹‹ 上一主题
|
下一主题 ››
17
2/2
‹‹
1
2
投票
交易
悬赏
活动
评价
|
打印
|
推荐
|
订阅
|
收藏
标题: 动态查询求教
sunchao
大道至简
来自 西安
精华贴数 0
个人空间
0
技术积分 4252 (327)
社区积分 104 (3369)
注册日期 2003-3-8
论坛徽章:5
#11
使用道具
发表于 2008-6-29 19:23
CREATE OR REPLACE PROCEDURE test(
v_tblname varchar2,
v_begin_time varchar2,
v_end_time varchar2
)
IS
v_sql VARCHAR2(5000);
BEGIN
v_sql := 'select decode(row_number() over(partition by aNumber order by aNumber),1, aNumber, null) aNumber,
a,ERROR,count(*) num,b,c
from '|| v_tblname || ' --tblname--》v_tblname
where Error=0
and COMMITTIME>='|| v_begin_time || 'and COMMITTIME<'|| v_end_time || '
group by aNumber,a,b,c,ERROR';
EXECUTE IMMEDIATE v_sql;
END;
应该是这样的吧
__________________
oracle 8 i/9i/10g unixware/solaris/aix/linux
QQ:273891948
MSN:chaosun2002@126.com
http://blog.itpub.net/sunchao
http://tahiti.oracle.com
只看该作者
阿日
2M-Never give up
精华贴数 0
个人空间
495
技术积分 1633 (1033)
社区积分 1123 (887)
注册日期 2004-1-4
论坛徽章:20
#12
使用道具
发表于 2008-6-29 19:26
用dbms_output的把sql输出来看看,然后在sqlplus下执行是否可以
v_sql VARCHAR2(5000) 这个最长是4000吧,记不太清了:(
[
本帖最后由 阿日 于 2008-6-29 19:28 编辑
]
__________________
我欲将心向明月,奈何明月照沟渠.
过去的都过去了,大不了从头再来,别回头,向前看!
http://blog.csdn.net/zxf_feng
只看该作者
lctweb
初级会员
精华贴数 0
个人空间
0
技术积分 32 (37926)
社区积分 0 (99503)
注册日期 2003-11-5
论坛徽章:0
#13
使用道具
发表于 2008-6-29 21:14
按11楼的方式是对的,但如何查看执行结果?
SQL> exec test('tdtable_26','1214409600','1214495999')
PL/SQL procedure successfully completed.
SQL>
只看该作者
taochenpfj
梦想中的版主
精华贴数 0
个人空间
0
技术积分 191 (9802)
社区积分 0 (932977)
注册日期 2006-5-16
论坛徽章:0
#14
使用道具
发表于 2008-6-29 23:01
冒昧的说一句啊,你这样写的话是不是容易被别人注入呢??
只看该作者
taochenpfj
梦想中的版主
精华贴数 0
个人空间
0
技术积分 191 (9802)
社区积分 0 (932977)
注册日期 2006-5-16
论坛徽章:0
#15
使用道具
发表于 2008-6-29 23:03
我实现过一个传入多个变量,可以查询多个列的存储过程,但是都被否定了,就是怕有sql注入
只看该作者
lctweb
初级会员
精华贴数 0
个人空间
0
技术积分 32 (37926)
社区积分 0 (99503)
注册日期 2003-11-5
论坛徽章:0
#16
使用道具
发表于 2008-6-30 08:46
执行后没有结果,是否是被别的程序注入呢??如果采用该存储过程无法实现,有没有别的方法可以实现?
SQL> CREATE OR REPLACE PROCEDURE test(
2 v_tblname varchar2,
3 v_begin_time varchar2,
4 v_end_time varchar2
5 )
6 IS
7 --variables declare
8 TYPE rct_cursor IS REF CURSOR ;
9 c rct_cursor ;
10 v_sql VARCHAR2(4000);
11 aNUMBER NUMBER(10);
12 a NUMBER(10);
13 ERROR NUMBER(5);
14 num NUMBER(5);
15 b NUMBER(5);
16 c NUMBER(5);
17 BEGIN
18 ---打印汇总
19 -- set column header
20 v_sql := 'select decode(row_number() over(partition by aNumber order by aNumber),1, aNumber, null) aNumber,
21 a,ERROR,count(*) num,b,c
22 from '|| v_tblname || '
23 where ErrorCode=0
24 and COMMITTIME>='|| v_begin_time || 'and COMMITTIME<'|| v_end_time || '
25 group by aNumber,a,b,c,ERROR';
26 dbms_output.put_line(v_sql);
27 open c for v_sql;
28 loop
29 fetch c into aNUMBER,a,ERROR,num,b,c;
30 exit when c%notfound;
31 dbms_output.put_line(aNUMBER||', '||a||', '||ERROR||', '||num||', '||b||', '||c);
32 end loop;
33 END;
34 /
Procedure created.
SQL> exce test('tdtable_26','1214409600','1214495999');
SP2-0734: unknown command beginning "exce test(..." - rest of line ignored.
SQL>
SQL>
SQL> execute test('tdtable_26','1214409600','1214495999');
PL/SQL procedure successfully completed.
SQL>
只看该作者
wuhuaT
勿忘我
来自 勿问我
精华贴数 0
个人空间
0
技术积分 1847 (882)
社区积分 479 (1442)
注册日期 2008-1-14
论坛徽章:9
#17
使用道具
发表于 2008-6-30 09:25
学习
__________________
活到老,学到老,玩到老,乐到老
只看该作者
17
2/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号
联系我们
法律顾问
控制面板首页
编辑个人资料
积分交易
公众用户组
好友列表
升级个人空间
基本概况
论坛排行
主题排行
发帖排行
积分排行
在线时间
管理团队
管理统计