专注于互联网--专注于架构

最新标签
网站地图
文章索引
Rss订阅

首页 »数据库 » sql变量:PL/SQL在from后面使用变量 以及输入' &字 »正文

sql变量:PL/SQL在from后面使用变量 以及输入' &字

来源: 发布时间:星期四, 2008年12月18日 浏览:2次 评论:0
="t18"> 在from后面使用变量 CREATE OR REPLACE FUNCTION GET_TABLE_COUNT(
I_TabNa IN VARCHAR2 ,
I_Owner IN VARCHAR2 DEFAULT NULL
)
RETURN NUMBER
IS
V_RtnVal NUMBER ;
V_CursorId INTEGER ;
V_SqlStr VARCHAR2(300) ;
BEGIN
V_CursorId := DBMS_SQL.OPEN_CURSOR ; IF LENGTHB( RTRIM( LTRIM( NVL( I_Owner , '' ) ) ) ) = 0 THEN
V_SqlStr := 'SELECT COUNT(*) FROM ' I_TabNa ;
ELSE
V_SqlStr := 'SELECT COUNT(*) FROM ' I_Owner '.' I_TabNa ;
END IF ; DBMS_SQL.PARSE( V_CursorId , V_SqlStr , DBMS_SQL.V7 ) ; DBMS_SQL.DEFINE_COLUMN( V_CursorId , 1 , 0 ) ; IF DBMS_SQL.EXECUTE( V_CursorId ) = 0 THEN
NULL ;
END IF ; IF DBMS_SQL.FETCH_ROWS( V_CursorId ) = 0 THEN
RETURN 0 ;
END IF ; DBMS_SQL.COLUMN_VALUE( V_CursorId , 1 , V_RtnVal ) ; DBMS_SQL.CLOSE_CURSOR( V_CursorId ) ; RETURN V_RtnVal ;
EXCEPTION
WHEN OTHERS THEN
DBMS_SQL.CLOSE_CURSOR( V_CursorId ) ;
-- DBMS_OUTPUT.PUT_LINE( V_SqlStr SQLERRM ) ;
RETURN 0 ;
END GET_TABLE_COUNT;
试验结果:
SQL> select GET_TABLE_COUNT( 'tab' ) from dual ; GET_TABLE_COUNT('TAB')
----------------------
22 SQL> select GET_TABLE_COUNT( 'spr' , 'testman') from dual ; GET_TABLE_COUNT('SPR','TESTMAN
------------------------------
15 SQL> select GET_TABLE_COUNT( 'U_Oausr' , 'tm') from dual ; GET_TABLE_COUNT('U_OAUSR','TM'
------------------------------
10 SQL> 介绍说明:
-- DBMS_SQL.DEFINE_COLUMN( V_CursorId , 1 , 0 ) ; 里“0”是什么意思?
DEFINE_COLUMN是用作定义数据类型区别数据类型有不太定义方式这里面“0”通俗点说就是“和‘0’数据类型意思”比如定义长度为200varchar2型时候可以简化为这样定义:DBMS_SQL.DEFINE_COLUMN( V_CursorId , 1 , 'tmpStr' , 200 )更多数据类型列定义请查看Oraclepl/sql文档里面很全
-- 另外如何用联编变量?
联编变量是种非常好传递参数方式而且不轻易出错但是既然称的为“联编变量”那就是它只能对Oracle中认为变量进行联编而刚才上面例子中表面是不能够作为变量因此不可以联编Oracle中认为出现在逻辑表达式右边才是变量例如可以这样进行联编变量:
......
V_SqlStr := 'SELECT COUNT(*) FROM TAB WHERE TName LIKE :I_Arg0 ' ; DBMS_SQL.PARSE( V_CursorId , V_SqlStr , DBMS_SQL.V7 ) ;
V_TabName := 'MYTAB' ;
DBMS_SQL.BIND_VARIABLE( V_CursorId , ':I_Arg0' , V_TabName '%' ) ;
......
8i以后版本这样写也行
CREATE OR REPLACE FUNCTION GET_TABLE_COUNT(
I_TabNa IN VARCHAR2 ,
I_Owner IN VARCHAR2 DEFAULT NULL
)
RETURN NUMBER
IS
V_RtnVal NUMBER ;
V_TabName VARCHAR2(300) ;
BEGIN
IF LENGTHB( RTRIM( LTRIM( NVL( I_Owner , '' ) ) ) ) = 0 THEN
V_TabName := I_TabNa ;
ELSE
V_TabName := I_Owner '.' I_TabNa ;
END IF ; EXECUTE IMMEDIATE 'SELECT COUNT(*) FROM ' V_TabName INTO V_RtnVal ;
RETURN V_RtnVal ;
EXCEPTION
WHEN OTHERS THEN
RETURN 0 ;
END GET_TABLE_COUNT ; SQL*PLUS环境输入'&'思路方法 我们知道在SQL*PLUS默认环境里会把'&'当成变量来处理. 有些时候我们也需要在SQL>符号下输入'&', 只需要改变SQL*PLUS下个环境变量即可.

   SQL> off; 是把默认&绑定变量功能取消, 可以把'&'当成普通处理 SQL> on; 打开&绑定变量功能, &后面串当变量使用. SQL> show ; 查看当前SQL*PLUS状态

举例介绍说明:
---------------------------------------------------------------
SQL> CREATE TABLE TEST3 (
ID NUMBER (2) PRIMARY KEY,
NAME VARCHAR2 (20));

SQL> show ;
"&" (hex 26)

SQL> insert o test3 values(1,'sgs&a&n');
Enter value for a: abc
Enter value for n: 456
old 1: insert o test3 values(1,'sgs&a&n')
1: insert o test3 values(1,'sgsabc456') 1 row created. SQL> commit; Commit complete. SQL> off; SQL> insert o test3 values(2,'sgs&a&n');

1 row created. SQL> commit; Commit complete.
SQL> select * from test3; ID NAME
-- --------------------
1 sgsabc456
2 sgs&a&n

相关文章

读者评论

  • 共0条 分0页

发表评论

  • 昵称:
  • 内容: