真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

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

這篇文章將為大家詳細(xì)講解有關(guān)SQL*Plus中怎么利用DATE類型綁定變量,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

創(chuàng)新互聯(lián)長期為上1000+客戶提供的網(wǎng)站建設(shè)服務(wù),團隊從業(yè)經(jīng)驗10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為廣漢企業(yè)提供專業(yè)的網(wǎng)站設(shè)計制作、網(wǎng)站設(shè)計,廣漢網(wǎng)站改版等技術(shù)服務(wù)。擁有十年豐富建站經(jīng)驗和眾多成功案例,為您定制開發(fā)。

SQL*Plus是DBA必不可少的工具,按照大神TK的話說:“不會使用SQL*Plus的DBA不是合格的DBA?!碑?dāng)然原話不是這么說的,但差不多就是這個意思,可見SQL*Plus的重要性。

SQL*Plus很好很強大,但也有一些局限,比如在SQL*Plus中使用綁定變量時,DATE類型就無法使用。
環(huán)境準(zhǔn)備:
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.

現(xiàn)在我們需要用MAKEDATE作為條件進(jìn)行查詢:
SELECT * FROM T1 WHERE MAKEDATE := :MD;

我們使用VAR來聲明變量:
SQL> VAR MD DATE
Usage: VAR[IABLE] [ [ 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的隱性轉(zhuǎn)換間接實現(xiàn)了DATE類型的使用(根據(jù)隱性轉(zhuǎn)換規(guī)則,VARCHAR2會轉(zhuǎn)換成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的設(shè)置,設(shè)置不正確會導(dǎo)致隱性轉(zhuǎn)換的失敗。

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


網(wǎng)站題目:SQL*Plus中怎么利用DATE類型綁定變量
瀏覽路徑:http://weahome.cn/article/ighjog.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部