首页
论坛
门户
空间
手机版
IXPUB
插件
收藏
设置
注册
登录
商店
搜索
培训
Wiki
Blog
归档
丛书
退出
ITPUB论坛
»
Oracle专题深入讨论
» 从v$sqlarea视图中怎么查看sql是否使用了绑定变量?
‹‹ 上一主题
|
下一主题 ››
投票
交易
悬赏
活动
评价
|
打印
|
推荐
|
订阅
|
收藏
标题:
[原创]
从v$sqlarea视图中怎么查看sql是否使用了绑定变量?
javaliu2006
精华贴数 0
个人空间
0
技术积分 462 (4132)
社区积分 4 (18859)
注册日期 2008-3-21
论坛徽章:0
#1
使用道具
发表于 2008-6-11 11:10
从v$sqlarea视图中怎么查看sql是否使用了绑定变量?
从v$sqlarea视图中怎么查看sql是否使用了绑定变量?
解析后的SQL与解析前的SQL,在形式上有什么区别?
普通变量与绑定变量在解析之后有什么区别,怎么区分?
谢谢!
只看该作者
javaliu2006
精华贴数 0
个人空间
0
技术积分 462 (4132)
社区积分 4 (18859)
注册日期 2008-3-21
论坛徽章:0
#2
使用道具
发表于 2008-6-11 12:59
从v$sqlarea视图中怎么查看sql是否使用了绑定变量?
解析后的SQL与解析前的SQL,在形式上有什么区别?
普通变量与绑定变量在解析之后有什么区别,怎么区分?
如:
SELECT ROWNUM NUM,
M.MANAGED_PORT_ID PORTID,
M.CODE PORTCODE,
E.EQUIPMENT_ID EQUID,
E.CODE EQUCODE,
B.CODE HLCODE
FROM CONNECTOR C,
MANAGED_PORT M,
EQUIPMENT E,
DEVICE_SIDE_PORT B,
(SELECT S.SIDE_ID SS
FROM SIDE S,
(SELECT A.NODE_ID AA, B.NODE_ID BB
FROM NODE A, NODE B
WHERE A.DEVICE_ID = :1
AND B.DEVICE_ID = :2) AA
WHERE S.NODE_ID_A = AA.AA
AND S.NODE_ID_B = AA.BB) SS
WHERE C.SIDE_ID = SS.SS
AND C.SIDEA_PORT_ID = M.MANAGED_PORT_ID
AND M.RSC_STATUS_CD = :"SYS_B_0"
AND C.SIDEB_PORT_ID = B.PORT_ID
AND E.EQUIPMENT_ID = M.EQUIPMENT_ID
AND M.CODE LIKE :"SYS_B_1"
AND M.RSC_SPEC_ID IN (:3)
AND C.RSC_STATUS_CD = :"SYS_B_2"
AND ROWNUM > :4
AND ROWNUM < :5
ORDER BY M.CODE, PORTID;
如上SQL中,:"SYS_B_0",:"SYS_B_1",:"SYS_B_2" 与 :4,:5 这几个变量哪些用的是绑定变理?怎么区分?
还有一个问题就是,SQL 中写死的常量,解析后,常量前会加“:”吗?,例如:解析前的SQL为:
select * from area where area_id=13101,解析后,是与前析前一样,还是会变成:select * from area where area_id=:13101 ,即在常量前加“:” ?
谢谢!
只看该作者
liqy103
一般会员
精华贴数 0
个人空间
0
技术积分 274 (7019)
社区积分 2 (27963)
注册日期 2006-1-22
论坛徽章:0
#3
使用道具
发表于 2008-6-11 13:39
有:的就是变量
只看该作者
nganhong
初级会员
精华贴数 0
个人空间
0
技术积分 46 (29320)
社区积分 0 (1281459)
注册日期 2007-2-26
论坛徽章:0
#4
使用道具
发表于 2008-6-13 09:02
如果看到這樣的綑綁變數,
:"SYS_B_0"
:"SYS_B_1"
:"SYS_B_2"
:"SYS_B_3"
該 sql 陳述原來應是 literal 字串但已經過 oracle parser 轉換
至於原來的值 可能要在原始碼中才能找出
當 cursor_sharing 是 similar 或者 force 時 才會改變 parser 成為這樣的行為
只看该作者
Yong Huang
版主
精华贴数 2
个人空间
0
技术积分 3994 (347)
社区积分 120 (3015)
注册日期 2001-10-9
论坛徽章:6
#5
使用道具
发表于 2008-6-15 06:38
There're many forms of bind variable notation for mid-tier apps, :[number], :P[number], :B[number], :v[number], etc, and of course :[word]. I think the :P[number] form is for Perl DBI. But other forms vary (Try select module, parsing_schema_name, sql_text from v$sql where parsing_schema_id != 0 and sql_text like '%:%' and see if you can find a pattern.) The number is sequentially assigned, not changing, e.g., 13101 to :13101. You can't have that many bind variables in one SQL statement!
The :"SYS_B_[number]" notation is for Oracle-converted bind variables, as nganhong said.
Original runtime values can be found in app tier source code, or v$sql_bind_capture in 10g (subject to a lot of limitations), or through 10046 event trace.
Obviously not all SQLs having a colon (:) are using bind variables, for instance, select * from emp where trunc(hiredate) = '20080101 00:00:00', or select * from document where text like '%He said:%'. Conversely, a SQL using bind variables must have a colon in it, although it can still have literal values: select * from emp where name=:1 and dept=123.
Yong Huang
只看该作者
javaliu2006
精华贴数 0
个人空间
0
技术积分 462 (4132)
社区积分 4 (18859)
注册日期 2008-3-21
论坛徽章:0
#6
使用道具
发表于 2008-6-16 09:42
谢谢版主的回答!
只看该作者
投票
交易
悬赏
活动
相关内容
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 技术
> Office开发
> Microsoft office system
> Office Business Application
> 微软企业级产品技术
> windows server
> SharePoint
> Exchange Server
> Biztalk
> 嵌入式及移动开发
> Windows Embedded 嵌入式技术
> Windows 移动设备
> 微软产品用户交流区
> .Net电子书籍&&书籍介绍
> .Net人才交流
技术积分榜
社区积分榜
徽章
电子杂志
会员
团队
统计
邮箱
游乐场
帮助
TOP
CopyRight 1999-2006 itpub.net All Right Reserved.
北京皓辰广域网络信息技术有限公司. 版权所有
E-mail:Webmaster@itpub.net
京ICP证:010037号
联系我们
法律顾问
控制面板首页
编辑个人资料
积分交易
公众用户组
好友列表
升级个人空间
基本概况
论坛排行
主题排行
发帖排行
积分排行
在线时间
管理团队
管理统计