SQL*Plus中使用DATE型別的繫結變數
SQL*Plus是DBA必不可少的工具,按照大神TK的話說:“不會使用SQL*Plus的DBA不是合格的DBA。”當然原話不是這麼說的,但差不多就是這個意思,可見SQL*Plus的重要性。
SQL*Plus很好很強大,但也有一些侷限,比如在SQL*Plus中使用繫結變數時,DATE型別就無法使用。
環境準備:
SQL> CREATE TABLE T1(ID NUMBER, NAME VARCHAR2(30), MAKEDATE DATE);
Table created.
SQL> INSERT INTO T1 VALUES(1, 'Emma',TO_DATE('20180206','YYYYMMDD'));
1 row created.
SQL> INSERT INTO T1 VALUES(2, 'Kevin', TO_DATE('20170101','YYYYMMDD'));
1 row created.
SQL> COMMIT;
Commit complete.
現在我們需要用MAKEDATE作為條件進行查詢:
SELECT * FROM T1 WHERE MAKEDATE := :MD;
我們使用VAR來宣告變數:
SQL> VAR MD DATE
Usage: VAR[IABLE] [ <variable> [ NUMBER | CHAR | CHAR (n [CHAR|BYTE]) |
VARCHAR2 (n [CHAR|BYTE]) | NCHAR | NCHAR (n) |
NVARCHAR2 (n) | CLOB | NCLOB | BLOB | BFILE
REFCURSOR | BINARY_FLOAT | BINARY_DOUBLE ] ]
可以看到,宣告DATE型別的變數無法透過,SQL*Plus反饋了一個VAR的使用方法。從使用方法中我們也可以看到確實沒有DATE型別。那怎麼使用DATE型別的繫結變數呢?可以透過一種變通的方法,如下:
SQL> ALTER SESSION SET NLS_DATE_FORMAT='YYYYMMDD';
Session altered.
SQL> VAR MD VARCHAR2(8)
SQL> BEGIN :MD := '20180206'; END;
2 /
PL/SQL procedure successfully completed.
SQL> SELECT * FROM T1 WHERE MAKEDATE = :MD;
ID NAME MAKEDATE
---------- ------------------------------ --------
1 Emma 20180206
這裡是用VARCHAR2型別代替DATE型別,使用Oracle的隱性轉換間接實現了DATE型別的使用(根據隱性轉換規則,VARCHAR2會轉換成DATE型別,具體可參考:)。
這裡需要注意的是NLS_DATE_FORMAT的設定,設定不正確會導致隱性轉換的失敗。
SQL*Plus很好很強大,但也有一些侷限,比如在SQL*Plus中使用繫結變數時,DATE型別就無法使用。
環境準備:
SQL> CREATE TABLE T1(ID NUMBER, NAME VARCHAR2(30), MAKEDATE DATE);
Table created.
SQL> INSERT INTO T1 VALUES(1, 'Emma',TO_DATE('20180206','YYYYMMDD'));
1 row created.
SQL> INSERT INTO T1 VALUES(2, 'Kevin', TO_DATE('20170101','YYYYMMDD'));
1 row created.
SQL> COMMIT;
Commit complete.
現在我們需要用MAKEDATE作為條件進行查詢:
SELECT * FROM T1 WHERE MAKEDATE := :MD;
我們使用VAR來宣告變數:
SQL> VAR MD DATE
Usage: VAR[IABLE] [ <variable> [ NUMBER | CHAR | CHAR (n [CHAR|BYTE]) |
VARCHAR2 (n [CHAR|BYTE]) | NCHAR | NCHAR (n) |
NVARCHAR2 (n) | CLOB | NCLOB | BLOB | BFILE
REFCURSOR | BINARY_FLOAT | BINARY_DOUBLE ] ]
可以看到,宣告DATE型別的變數無法透過,SQL*Plus反饋了一個VAR的使用方法。從使用方法中我們也可以看到確實沒有DATE型別。那怎麼使用DATE型別的繫結變數呢?可以透過一種變通的方法,如下:
SQL> ALTER SESSION SET NLS_DATE_FORMAT='YYYYMMDD';
Session altered.
SQL> VAR MD VARCHAR2(8)
SQL> BEGIN :MD := '20180206'; END;
2 /
PL/SQL procedure successfully completed.
ID NAME MAKEDATE
---------- ------------------------------ --------
1 Emma 20180206
這裡需要注意的是NLS_DATE_FORMAT的設定,設定不正確會導致隱性轉換的失敗。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/13885898/viewspace-2150916/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 【SQL】在SQLPLUS中使用繫結變數的寫法SQL變數
- SQL Developer中使用繫結變數SQLDeveloper變數
- PL/SQL中繫結變數使用的簡單測試SQL變數
- v$sql_bind_capture與timestamp型別的繫結變數的數值SQLAPT型別變數
- 關於pl/sql中的繫結變數SQL變數
- 【sql調優】使用繫結變數(二)SQL變數
- 【sql調優】使用繫結變數(一)SQL變數
- 關於sql_profile中的繫結變數SQL變數
- oracle 查詢未使用繫結變數的sqlOracle變數SQL
- SQL使用繫結變數,測試例項。SQL變數
- Oracle中如何查詢未使用繫結變數的SQL語句?Oracle變數SQL
- 查詢出系統中沒有使用繫結變數的SQL變數SQL
- 查詢沒有使用繫結變數的sql zt變數SQL
- 關於繫結變數的SQL繫結什麼值變數SQL
- SQL Server日期資料型別DATE的使用SQLServer資料型別
- SQL Server動態SQL,繫結變數SQLServer變數
- Oracle中date型別使用注意Oracle型別
- 繫結變數在靜態sql和動態sql中變數SQL
- 檢視未繫結變數的sql變數SQL
- 獲取sql繫結變數的值SQL變數
- PLSQL使用繫結變數SQL變數
- V$sql查詢未使用繫結變數的語句SQL變數
- oracle找出沒有使用繫結變數的sql語句Oracle變數SQL
- 尋找沒有使用繫結變數的sql語句變數SQL
- 【優化】使用繫結變數 OR 不使用繫結變數,這不是問題!優化變數
- 繫結變數的使用範圍變數
- 關於繫結變數的使用變數
- 在oracle的plsql中為cursor使用繫結變數OracleSQL變數
- 【最佳化】使用繫結變數 OR 不使用繫結變數,這不是問題!變數
- 使用繫結變數的一點總結!變數
- 【SQL 調優】繫結變數窺測SQL變數
- 【sql調優】繫結變數與CBOSQL變數
- 統計沒有繫結變數SQL變數SQL
- OLTP系統中儘量使用繫結變數變數
- 關於DSS中的繫結變數變數
- c++中的變數型別_C ++中的變數C++變數型別
- 統計未用繫結變數的sql語句變數SQL
- 繫結變數變數