动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ Oracle教程 ]的信息

本月文章推荐
.Oracle数据库体系结构.
.在slackware 10下安装Oracle 10.
.exp/imp导出导入工具的使用.
.神秘的 ORACLE DUAL.
.Linux拨号上网故障诊断.
.常见数据库系统之比较 - Oracle数.
.为最佳性能而调优 Red Hat(4).
.快速建立数据字典我如此设计小型.
.Oracle816中如何启动EnterpriseM.
.有关Oracle数据库的备份情况.
.Oracle9i中取得建表和索引的DDL语.
.尝试一些UNIX的提示和技巧.
.ORACLE问题,每天10问(四).
.9i新特性之——在线表格重定义研.
.用脚本和查询主动监视Oracle 9i性.
.Red Hat Linux 7.1使用手册(中).
.Oracle 10g RAC与SLES9.
.如何使用ExternalContext类.
.Linux日志管理详解.
.自定义临时表实现及在Oracle Spa.

如何正确的在对in操作使用变量绑定

发表日期:2008-2-9 |



  家都知道在sql语句中变量绑定的重大意义,甚至有高人指出:一个应用想要它变的很糟糙的话,只要不使用变量绑定就可以了。这话的确不假。这时可能有人就会问:我该绑定的都绑定了,可是我实在无法想到好的方法在in操作符中使用变量绑定。下面的方法可以解决这个疑问。
   
  我们知道in操作符接受两种list, 一个是由一个个item组成的list, 另一个是由另一个表中选出的list。第一种方式由于值个数不一定,变量绑定具有一定的困难。于是我们思路就集中到预备将一个字符串传入到sql语句中,然后使用一个方法将字符串parse成一个table, 再传回in operator:
   
  首先我们来创建方法,及由此方法返回的table类型:
  rudolf@test9i> create or replace type numTableType as table
  2    of number
  3 /
  
  Type created.
  
  rudolf@test9i> create or replace function str2numList( p_string in varchar2 ) return
  2 numTableType
  3 as
  4   v_str  long default p_string ',';
  5   v_n    number;
  6   v_data  numTableType := numTableType();
  7 begin
  8   loop
  9     v_n := to_number(instr( v_str, ',' ));
  10     exit when (nvl(v_n,0) = 0);
  11     v_data.extend;
  12     v_data( v_data.count ) := ltrim(rtrim(substr(v_str,1,v_n-1)));
  13     v_str := substr( v_str, v_n+1 );
  14   end loop;
  15   return v_data;
  16 end;
  17 /
  
  Function created.
  
  我们把下列语句:
  select object_name from t where object_id in ( xx,xxx,xxx,...);
  改为:
  select object_name from t
  where object_id in
  ( select * from THE ( select cast( str2numList(:variable ) as numtableType ) from dual )
  );
  
  现在我们来看看是否达到了我们的目的:
  rudolf@test9i> var STR varchar2(3000)
  
  rudolf@test9i> exec :STR := '5770,1810,4481'
  
  PL/SQL procedure sUCcessfully completed.
  
  rudolf@test9i> alter session set events= '10046 trace name context forever, level 4'
  2 /
  
  Session altered.
  
  rudolf@test9i> select object_id,object_name from t where object_id in (
  2   select * from THE ( select cast( str2numList(:STR ) as numtableType ) from
  3  dual ) )
  4
  rudolf@test9i> /
  
  OBJECT_ID OBJECT_NAME
  ---------- ------------------------------
  1810 ALL_ALL_TABLES
  4481 AGGXMLINPUTTYPE
  5770 ALL_APPLY
  
  检查dump文件,我们看到(注重星号的行):
  
  PARSING IN CURSOR #1 len=146 dep=0 uid=81 oct=3 lid=81 tim=1036636837633718 hv=2833917919 ad='529b9f48'
  select object_id,object_name from t where object_id in (
  select * from THE ( select cast( str2numList(:STR ) as numtableType ) from
  dual ) )
  END OF STMT
  PARSE #1:c=0,e=655,p=0,cr=0,cu=0,mis=1,r=0,dep=0,og=0,tim=1036636837633701
  BINDS #1:         *****
  bind 0: dty=1 mxl=2000(200) mal=00 scl=00 pre=00 oacflg=03 oacfl2=10 size=2000 offset=0
  bfp=406402fc bln=2000 avl=14 flg=05
  value="5770,
1810,4481"
  EXEC #1:c=0,e=245,p=0,cr=0,cu=0,mis=0,r=0,dep=0,og=4,tim=1036636837645450
  FETCH #1:c=20000,e=16739,p=0,cr=52,cu=0,mis=0,r=1,dep=0,og=4,tim=1036636837662283
  FETCH #1:c=0,e=4644,p=0,cr=0,cu=0,mis=0,r=2,dep=0,og=4,tim=1036636837667979
上一篇:使用ORACLE数据库时的WEB分页方法 人气:880
下一篇:在Oracle中实现数字进制转换完全版 人气:737
浏览全部Oracle教程的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-10-7 Web Wiz Forums(论坛系统) v9.53
2008-10-7 Web Wiz Forums(论坛系统) v9.53
2008-10-7 Web Wiz Forums(论坛系统) v9.53
2008-10-7 HDWiki v4.0.1 bulid 081007 UTF
2008-10-7 迅易评选投票管理系统 v10.0
2008-10-7 HDWiki v4.0.1 bulid 081007 GBK
2008-10-7 Bitrac单用户博客 v1.14 bulid 0
2008-10-7 OpenX(广告管理系统) v2.6.2 多国
2008-10-7 乐铺网店系统免费普及版 v3.41
2008-9-29 酷狗音乐(原KuGoo)2008 v5.310 正
2008-9-29 QQTab 1.1
2008-9-29 网络传送带 Net Transport 2.64a
2008-9-29 谷歌金山词霸v1.8
2008-9-29 TweakVI 1.0 Build 1090
2008-9-29 ACDSee Pro 2.5 Build 333 汉化绿
2008-9-29 Winamp v5.541(2189) 周明波简体
2008-9-27 CCleaner 2.12.651
2008-9-27 Mozilla Thunderbird 2.0.0.17 英
  发表评论
姓 名: 验证码:
内 容:
站长工具:网站收录查询 | Google PR查询 | ALEXA排名查询 | CSS在线编辑器 | 广告代码 | js/vbs加密 | md5加密 | 进制转换 | UTF-8 转换工具 | Html转换js | Html转换asp | Html转换php | Html转换perl
实用工具:汉字翻译拼音 | 拼音字典 | 符号对照表 | 个税计算 | 实时汇率查询换算 | 经典小工具 | 汉字简繁转换 | 普通单位换算 | 公制单位换算 | 生辰老黄历 | 国内电话区号 | 国家代码与域名缩写 | 文字加密解密 | 健康查询 | 万年历 | 汉字横竖排版 | 手机号码查询 | 计算器 | ip搜索
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号
ホームページ制作 不動産検索システム 求人情報
防水工事·改修工事 フットサル大会 探偵
SEO対策 中国語教室 ホームページ作成