一。可以使用to_char()函數(shù)把日期轉(zhuǎn)換成number
網(wǎng)站建設(shè)哪家好,找成都創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、小程序開發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了鹿泉免費(fèi)建站歡迎大家使用!
to_char(sysdate, 'yyyymm); 返回'201002' 再與“200908”比較
二?;蛘呤褂胻o_date()函數(shù)把200908轉(zhuǎn)換成日期
to_date()參數(shù):
日期格式參數(shù) 含義說(shuō)明
D 一周中的星期幾
DAY 天的名字,使用空格填充到9個(gè)字符
DD 月中的第幾天
DDD 年中的第幾天
DY 天的簡(jiǎn)寫名
IW ISO標(biāo)準(zhǔn)的年中的第幾周
IYYY ISO標(biāo)準(zhǔn)的四位年份
YYYY 四位年份
YYY,YY,Y 年份的最后三位,兩位,一位
HH 小時(shí),按12小時(shí)計(jì)
HH24 小時(shí),按24小時(shí)計(jì)
MI 分
SS 秒
MM 月
Mon 月份的簡(jiǎn)寫
Month 月份的全名
W 該月的第幾個(gè)星期
WW 年中的第幾個(gè)星期
if first_name='x' then
last_name:='y' ;
end if ;
注意last_name要改成是in out類型
在ORACLE中,將空字符串視為NULL,任何值與NULL比較結(jié)果都為NULL。如此一來(lái),在比較兩個(gè)字符串的時(shí)候就會(huì)出現(xiàn)意外。請(qǐng)看以下的例子:DECLAREi VARCHAR2(10) := NULL;
v VARCHAR2(10) := 'ABC';BEGINIF(i = v) THEN
v VARCHAR2(10) := 'ABC';BEGINIF(i v) THEN
DBMS_OUTPUT.PUT_LINE('不等');ELSEDBMS_OUTPUT.PUT_LINE('相等');END IF;END;看上去和第一個(gè)程序沒有太大的差別,很容易就得出結(jié)果:'不等'。呵呵。你確定結(jié)果就是這個(gè)嗎?那么請(qǐng)你在SQLPLUS測(cè)試一下,來(lái)驗(yàn)證你是正確的。很可惜,正確的結(jié)果應(yīng)該是:'相等'。是不是很詫異?正如開始所說(shuō)的:任何值與NULL比較結(jié)果都為NULL。即在第一個(gè)程序中的i=v比較的結(jié)果應(yīng)該是NULL,而第二個(gè)程序中的iv比較的結(jié)果也是NULL。當(dāng)IF結(jié)構(gòu)中的條件為NULL時(shí),將跳過(guò)當(dāng)前的分支進(jìn)入到ELSE或者是結(jié)束。不行嗎?那你運(yùn)行一下以下的程序?qū)⒖梢缘鹊津?yàn)證:BEGINIF(NULL) THEN
DBMS_OUTPUT.PUT_LINE('NOT NULL');ELSEDBMS_OUTPUT.PUT_LINE('NULL');END IF;END;結(jié)果輸出的是:'NULL'。
1、當(dāng)i和v都為NULL的時(shí)候,認(rèn)為i和v相等。i IS NULL AND v IS NULL(不要寫成這樣:i = v。從上邊的分析我們可以知道這樣寫的結(jié)果為NULL)。
2、當(dāng)i和v中只有一個(gè)為NULL,肯定不相等。
3、當(dāng)i和v都不為NULL的時(shí)候,我們就可以用‘=’號(hào)來(lái)判斷它們是否相等。i IS NOT NULL AND v IS NOT NULL AND i = v。
根據(jù)以上三點(diǎn),我們可以得出判斷i和v相等的條件表達(dá)式:i IS NULL AND v IS NULL OR i IS NOT NULL AND v IS NOT NULL AND i = v。
那么兩個(gè)字符串不相等的條件表達(dá)式只需要判斷相等的表達(dá)式為FALSE就可以了。
把判斷兩個(gè)字符串是否相等的功能寫成函數(shù):
CREATE OR REPLACE FUNCTION ISEQUAL(VAR1 IN VARCHAR2,
VAR2 IN VARCHAR2)RETURN NUMBER -- 0:不等 1:相等 -1:錯(cuò)誤ISIF(VAR1 IS NULL AND VAR2 IS NULL OR VAR1 IS NOT NULL AND VAR2 IS NOT NULL AND VAR1 = VAR2) THENRETURN 1;ELSERETURN 0;ENF IF;BEGINEXCEPTIONWHEN OTHERS THENRETURN -1;END;以下上測(cè)試程序:DECLAREVAR1 VARCHAR2(10) := NULL;
直接運(yùn)行mysql安裝目錄/libexec/mysqld啟動(dòng)數(shù)據(jù)庫(kù)(以前是運(yùn)行bin/safe_mysqld啟動(dòng)數(shù)據(jù)庫(kù)),增加參數(shù)“--log-bin=mysql安裝目錄/man/主機(jī)名-bin.log”,操作數(shù)據(jù)庫(kù)后生成了2個(gè)文件:主機(jī)名-bin.001,主機(jī)名-bin.index.在mysqlshow slave status;顯示Slave_Running為No,在mysqlslave start;“ERROR 1200: The server is not configured as slave, fix in config file or with CHANGE MASTER TO”!
在PLSQL中使用EXECUTE IMMEDIATE語(yǔ)句處理動(dòng)態(tài)SQL語(yǔ)句。
語(yǔ)法如下:
EXECUTE IMMEDIATE dynamic_string
[INTO {define_variable[, define_variable]... | record}]
[USING [IN | OUT | IN OUT] bind_argument
[, [IN | OUT | IN OUT] bind_argument]...]
[{RETURNING | RETURN} INTO bind_argument[, bind_argument]...];
dynamic_string是代表一條SQL語(yǔ)句或一個(gè)PL/SQL塊的字符串表達(dá)式,
define_variable是用于存放被選出的字段值的變量,
record是用戶定義或%ROWTYPE類型的記錄,用來(lái)存放被選出的行記錄。
輸入bind_argument參數(shù)是一個(gè)表達(dá)式,它的值將被傳入(IN模式)或傳出(OUT模式)或先傳入再傳出(IN OUT模式)到動(dòng)態(tài)SQL語(yǔ)句或是PL/SQL塊中。一個(gè)輸出bind_argument參數(shù)就是一個(gè)能保存動(dòng)態(tài)SQL返回值的變量。
除了多行查詢外,動(dòng)態(tài)字符串可以包含任何SQL語(yǔ)句(不含終結(jié)符)或PL/SQL塊(含終結(jié)符)。
字符串中可以包括用于參數(shù)綁定的占位符。
但是,不可以使用綁定參數(shù)為動(dòng)態(tài)SQL傳遞模式對(duì)象。
在用于單行查詢時(shí),INTO子句要指明用于存放檢索值的變量或記錄。
對(duì)于查詢檢索出來(lái)的每一個(gè)值,INTO子句中都必須有一個(gè)與之對(duì)應(yīng)的、類型兼容的變量或字段。
在用于DML操作時(shí),RETURNING INTO子句要指明用于存放返回值的變量或記錄。
對(duì)于DML語(yǔ)句返回的每一個(gè)值,INTO子句中都必須有一個(gè)與之對(duì)應(yīng)的、類型兼容的變量或字段。
我們可以把所有的綁定參數(shù)放到USING子句中。默認(rèn)的參數(shù)模式是IN。
對(duì)于含有RETURNING子句的DML語(yǔ)句來(lái)說(shuō),我們可以把OUT參數(shù)放到RETURNING INTO之后,并且不用指定它們的參數(shù)模式,因?yàn)槟J(rèn)就是OUT。
如果我們既使用了USING又使用RETURNING INTO,那么,USING子句中就只能包含IN模式的參數(shù)了。
運(yùn)行時(shí),動(dòng)態(tài)字符串中的綁定參數(shù)會(huì)替換相對(duì)應(yīng)的占位符。所以,每個(gè)占位符必須與USING子句和/或RETURNING INTO子句中的一個(gè)綁定參數(shù)對(duì)應(yīng)。我們可以使用數(shù)字、字符和字符串作為綁定參數(shù),但不能使用布爾類型(TRUE,F(xiàn)ALSE和NULL)。要把空值傳遞給動(dòng)態(tài)字符串,我們就必須使用工作區(qū)。
動(dòng)態(tài)SQL支持所有的SQL類型。所以,定義變量和綁定變量都可以是集合、LOB,對(duì)象類型實(shí)例和引用。
作為一項(xiàng)規(guī)則,動(dòng)態(tài)SQL是不支持PL/SQL特有的類型的。這樣,它就不能使用布爾型或索引表。
我們可以重復(fù)為綁定變量指定新值執(zhí)行動(dòng)態(tài)SQL語(yǔ)句。但是,每次都會(huì)消耗很多資源,因?yàn)镋XECUTE IMMEDIATE在每次執(zhí)行之前都需要對(duì)動(dòng)態(tài)字符串進(jìn)行預(yù)處理。
第一,我們要知道,阿里的OceanBase是分布式數(shù)據(jù)庫(kù),分布式數(shù)據(jù)庫(kù)相比傳統(tǒng)的集中式數(shù)據(jù)庫(kù)有先天的優(yōu)勢(shì),性能優(yōu)于集中式數(shù)據(jù)庫(kù)是必然的結(jié)果,理論上來(lái)講,分布式數(shù)據(jù)庫(kù)是傳統(tǒng)集中式數(shù)據(jù)庫(kù)性能的數(shù)倍甚至數(shù)十倍,但是我們看到的僅僅是兩倍的性能,可以說(shuō),從這一點(diǎn)上來(lái)看,阿里的分布式數(shù)據(jù)庫(kù)沒有體現(xiàn)出分布式數(shù)據(jù)庫(kù)的優(yōu)勢(shì),或者說(shuō),阿里的分布式數(shù)據(jù)庫(kù)技術(shù)還有很大的上升空間。
第二,從成本的角度來(lái)考慮,OceanBase的測(cè)試結(jié)果構(gòu)建在近4億元系統(tǒng)的之上,平均每筆訂單成本6.25元人民幣。Oracle 11g的測(cè)試結(jié)果構(gòu)建在3000萬(wàn)美元的基礎(chǔ)上,平均每筆訂單成本7元人民幣。似乎打個(gè)平手,但這里面就很值得玩味的了,Oracle無(wú)論是硬件還是軟件,都是基于自家生產(chǎn),成本本來(lái)就很高,而阿里云是基于PC Server,操作系統(tǒng)使用的免費(fèi)的linux,成本理應(yīng)很低,而現(xiàn)在的硬件成本相比2011年要便宜不止數(shù)倍的價(jià)格。資源使用效率上,OceanBase平均8928筆/核/2.5GHz,Oracle 11g平均17361筆/核/1.65GHz。這樣算下來(lái)的話,阿里的資源使用效率要遠(yuǎn)遠(yuǎn)低于Oracle, 且成本比Oracle高出很多。這就像我們的GDP一樣,總量領(lǐng)先,人均還有很大的差距,所以對(duì)于國(guó)內(nèi)的軟件人來(lái)說(shuō),還需謙虛謹(jǐn)慎,繼續(xù)努力。
說(shuō)到此,孰優(yōu)孰略,相信你心里應(yīng)該有個(gè)數(shù)了