中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SQL*Plus中怎么利用DATE類型綁定變量

發布時間:2021-08-05 15:32:03 來源:億速云 閱讀:127 作者:Leah 欄目:關系型數據庫

這篇文章將為大家詳細講解有關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類型,具體可參考:https://docs.oracle.com/en/database/oracle/oracle-database/12.2/sqlrf/Data-Type-Comparison-Rules.html#GUID-98BE3A78-6E33-4181-B5CB-D96FD9DC1694)。

這里需要注意的是NLS_DATE_FORMAT的設置,設置不正確會導致隱性轉換的失敗。

關于SQL*Plus中怎么利用DATE類型綁定變量就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

杂多县| 清河县| 徐汇区| 昂仁县| 柯坪县| 留坝县| 东山县| 方山县| 墨竹工卡县| 云阳县| 漠河县| 桂林市| 金山区| 许昌市| 玛曲县| 长宁区| 湖南省| 馆陶县| 温州市| 尤溪县| 汶上县| 乐山市| 奉节县| 永顺县| 南郑县| 荣昌县| 三台县| 株洲县| 仙游县| 濉溪县| 缙云县| 资讯| 温州市| 乌兰察布市| 永安市| 云安县| 武冈市| 阿拉善左旗| 广灵县| 乡城县| 蛟河市|