SQLite教程(六):表達(dá)式詳解
一、常用表達(dá)式:
和大多數(shù)關(guān)系型數(shù)據(jù)庫一樣,SQLite能夠很好的支持SQL標(biāo)準(zhǔn)中提供的表達(dá)式,其函數(shù)也與SQL標(biāo)準(zhǔn)保持一致,如:
||
* / %
+ -
<< >> & |
< <= > >=
= == != <> IS IS NOT IN LIKE
AND
OR
~ NOT
在上面的表達(dá)式中,唯一需要說明的是"||",該表達(dá)式主要用于兩個(gè)字符串之間的連接,其返回值為連接后的字符串,即便該操作符兩邊的操作數(shù)為非字符串類型,在執(zhí)行該表達(dá)式之前都需要被提前轉(zhuǎn)換為字符串類型,之后再進(jìn)行連接。
二、條件表達(dá)式:
該表達(dá)式的語法規(guī)則如下:
1). CASE x WHEN w1 THEN r1 WHEN w2 THEN r2 ELSE r3 END
2). CASE WHEN x=w1 THEN r1 WHEN x=w2 THEN r2 ELSE r3 END
對(duì)于第一種情況,條件表達(dá)式x只需計(jì)算一次,然后分別和WHEN關(guān)鍵字后的條件逐一進(jìn)行比較,直到找到相等的條件,其比較規(guī)則等價(jià)于等號(hào)(=)表達(dá)式。如果找到匹配的條件,則返回其后THEN關(guān)鍵字所指向的值,如果沒有找到任何匹配,則返回ELSE關(guān)鍵字之后的值,如果不存在ELSE分支,則返回NULL。對(duì)于第二種情況,和第一種情況相比,唯一的差別就是表達(dá)式x可能被多次執(zhí)行,比如第一個(gè)WHEN條件不匹配,則繼續(xù)計(jì)算后面的WHEN條件,其它規(guī)則均與第一種完全相同。最后需要說明的是,以上兩種形式的CASE表達(dá)式均遵守短路原則,即第一個(gè)表達(dá)式的條件一旦匹配,其后所有的WHEN表達(dá)式均不會(huì)再被執(zhí)行或比較。
三、轉(zhuǎn)換表達(dá)式:
該表達(dá)式的語法規(guī)則如下:
CAST(expr AS target_type)
該表達(dá)式會(huì)將參數(shù)expr轉(zhuǎn)換為target_type類型,具體的轉(zhuǎn)換規(guī)則見如下列表:
目標(biāo)類型 | 轉(zhuǎn)換規(guī)則描述 |
TEXT | 如果轉(zhuǎn)換INTEGER或REAL類型的值到TEXT類型直接轉(zhuǎn)換即可,就像C/C++接口函數(shù)sqlite3_snprintf所完成的工作。 |
REAL | 如果轉(zhuǎn)換TEXT類型的值到REAL類型,在該文本的最前部,將可以轉(zhuǎn)換為實(shí)數(shù)的文本轉(zhuǎn)換為相應(yīng)的實(shí)數(shù),其余部分忽略。其中該文本值的前導(dǎo)零亦將被全部忽略。如果該文本值沒有任何字符可以轉(zhuǎn)換為實(shí)數(shù),CAST表達(dá)式的轉(zhuǎn)換結(jié)果為0.0。 |
INTEGER | 如果轉(zhuǎn)換TEXT類型的值到INTEGER類型,在該文本的最前部,將可以轉(zhuǎn)換為整數(shù)的文本轉(zhuǎn)換為相應(yīng)的整數(shù),其余部分忽略。其中該文本值的前導(dǎo)零亦將被全部忽略。如果該文本值沒有任何字符可以轉(zhuǎn)換為整數(shù),CAST表達(dá)式的轉(zhuǎn)換結(jié)果為0。 如果轉(zhuǎn)換將一個(gè)實(shí)數(shù)值轉(zhuǎn)換為INTEGER類型,則直接截?cái)鄬?shí)數(shù)小數(shù)部分。如果實(shí)數(shù)過大,則返回最大的負(fù)整數(shù):-9223372036854775808。 |
NUMERIC | 如果轉(zhuǎn)換文本值到NUMERIC類型,則先將該值強(qiáng)制轉(zhuǎn)換為REAL類型,只有在將REAL轉(zhuǎn)換為INTEGER不會(huì)導(dǎo)致數(shù)據(jù)信息丟失以及完全可逆的情況下,SQLite才會(huì)進(jìn)一步將其轉(zhuǎn)換為INTEGER類型。 |
最后需要說明的是,如果expr為NULL,則轉(zhuǎn)換的結(jié)果也為NULL。
相關(guān)文章
Win11下基于VS2022編譯SQLite3源碼的實(shí)現(xiàn)步驟
本文主要介紹了Win11下基于VS2022編譯SQLite3源碼的實(shí)現(xiàn)步驟,文中通過圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-09-09SQLite教程(五):索引和數(shù)據(jù)分析/清理
這篇文章主要介紹了SQLite教程(五):索引和數(shù)據(jù)分析/清理,本文講解了創(chuàng)建索引、刪除索引、重建索引、數(shù)據(jù)分析、數(shù)據(jù)清理等內(nèi)容,需要的朋友可以參考下2015-05-05sqlite循環(huán)批量插入數(shù)據(jù)采用批處理文件實(shí)現(xiàn)
需要在sqlite數(shù)據(jù)庫中插入大量測(cè)試數(shù)據(jù),需要通過一個(gè)批處理文件來循環(huán)調(diào)用插入sqlite語句,感興趣的朋友可以參考下哈,希望可以幫助到你2013-04-04python之sqlalchemy創(chuàng)建表的實(shí)例詳解
這篇文章主要介紹了數(shù)據(jù)庫之sqlalchemy創(chuàng)建表的實(shí)例詳解的相關(guān)資料,希望通過本文能幫助到大家,讓大家掌握理解這部分內(nèi)容,需要的朋友可以參考下2017-10-10SQLite3中的日期時(shí)間函數(shù)使用小結(jié)
這篇文章主要介紹了SQLite3中的日期時(shí)間函數(shù)使用小結(jié),同時(shí)介紹了一些SQLite數(shù)據(jù)庫的基本知識(shí),需要的朋友可以參考下2014-05-05