MySQL運算符使用方法全解析
1、算數(shù)運算符
算術(shù)運算符主要用于數(shù)學(xué)運算,可以連接運算符前后的兩個數(shù)值或表達(dá)式,對數(shù)值或表達(dá)式進(jìn)行加(+)、減(-)、乘(*)、除(/)以及取模(%)運算。
(1)加減運算符

- 一個整數(shù)類型的值對整數(shù)進(jìn)行加法和減法操作,結(jié)果還是一個整數(shù);
- 一個整數(shù)類型的值對浮點數(shù)進(jìn)行加法和減法操作,結(jié)果是一個浮點數(shù);
- 加法與減法優(yōu)先級相同,先進(jìn)行哪一個的結(jié)果都一樣;
- 在MySQL中,如果加號兩邊出現(xiàn)字符串等非數(shù)值類型,先轉(zhuǎn)換為數(shù)值,如果不能轉(zhuǎn)為數(shù)值,再按照數(shù)字0進(jìn)行運算。
(2)乘除運算符

- 一個整數(shù)除以整數(shù)(不為1)后,不管是否可以除盡,結(jié)果都是一個浮點數(shù)(保留四位);
- 乘法與除法優(yōu)先級相同,無論先進(jìn)行哪一個,結(jié)果都一樣;
- 在數(shù)學(xué)運算中,0不能作為除數(shù),但是在MySQL中,一個數(shù)除以0的結(jié)果是NULL。
(3)取模運算

2、比較運算符
比較運算符用來對表達(dá)式左邊的操作數(shù)和右邊的操作數(shù)進(jìn)行比較,比較結(jié)果為真則返回1,比較結(jié)果為假則返回0,其他情況返回NULL。
(1)等于運算符

遵循以下規(guī)則:
- 如果等號兩邊的值、字符串或表達(dá)式都為字符串,則MySQL會按照字符串進(jìn)行比較,其比較的是每個字符串中字符的ANSI編碼是否相等。
- 如果等號兩邊的值都是整數(shù),則MySQL會按照整數(shù)來比較兩個值的大小。
- 如果等號兩邊的值一個是整數(shù),另一個是字符串,則MySQL會將字符串轉(zhuǎn)化為數(shù)字進(jìn)行比較。如果轉(zhuǎn)換不成功,則將字符串看做0比較。
- 如果等號兩邊的值、字符串或表達(dá)式中有一個為NULL,則比較結(jié)果為NULL。
(2)安全等于運算符
安全等于運算符(<=>)作用和等于運算符相似,唯一區(qū)別在于安全等于運算符可以對NULL進(jìn)行判斷。

- 在兩個操作數(shù)均為NULL時,其返回值為1,而不為NULL;
- 當(dāng)一個操作數(shù)為NULL時,其返回值為0,而不為NULL。
(3)不等于運算符
不等于運算符( <> 和 != ),同樣不能判斷NULL,有一個為NULL ,結(jié)果就為NULL。
(4)非符號類型的運算符
① IS NULL(為空)、 IS NOT NULL(不為空)、ISNULL(為空)


② LEAST()最小值、GREATEST(最大值)

③ BETWEEN AND(查詢兩值之間) 包含查詢邊界

④ IN (屬于)、NOT IN(不屬于)

- between and 體現(xiàn)的是區(qū)間內(nèi)的連續(xù)值;in 和 not in是列表中羅列的離散值。
⑤ LIKE (模糊匹配)

⑥ REGEXP、RLIKE(正則表達(dá)式)

規(guī)則:
- '^'匹配以該字符后面的字符開頭的字符串。
- '$'匹配以該字符前面的字符結(jié)尾的字符串。
- '.'匹配任何一個單字符。
- "[...]"匹配在方括號內(nèi)的任何字符(或的關(guān)系);"[a-z]"匹配任何字母。
- '*'匹配零個或多個在它前面的字符;"[0-9]*"匹配任何數(shù)量的數(shù)字。
3、邏輯運算符
邏輯運算符主要判斷表達(dá)式的真假,在MySQL中,邏輯運算符的返回結(jié)果為1、0或NULL
(1)邏輯非運算符
邏輯非運算符(NOT或!)表示給定值取反,當(dāng)給定值為NULL時也返回NULL。

(2)邏輯與運算符
邏輯與運算符(AND或&&),同真為1,有假為0,其余為NULL。

(3)邏輯或運算符
邏輯或運算符(OR 或 ||),有真為真,兩個都為NULL則為NULL。

(4)邏輯異或運算符
邏輯異或運算符(XOR),有NULL則NULL,不同為1。

4、位運算符
位運算符是在二進(jìn)制上計算的運算符。會將操作數(shù)先變?yōu)槎M(jìn)制數(shù),然后進(jìn)行位運算,最后將計算結(jié)果從二進(jìn)制變回十進(jìn)制。
(1)按位與運算符
按位與運算(&)將操作數(shù)的二進(jìn)制逐位進(jìn)行邏輯與運算。

- 1的二進(jìn)制 0001,2的二進(jìn)制0010,3的二進(jìn)制0011。結(jié)果仍以十進(jìn)制展示。
(2)按位或運算符
按位或運算(|)將操作數(shù)的二進(jìn)制逐位進(jìn)行邏輯或運算。

(3)按位異或運算符
按位異或運算符(^)將操作數(shù)的二進(jìn)制逐位進(jìn)行邏輯異或運算。

(4)按位取反運算符
按位取反運算符(~)將操作數(shù)的二進(jìn)制逐位進(jìn)行取反運算。

(5)按位右移運算符
按位右移運算符(>>)將給定的值的二進(jìn)制數(shù)的所有位右移指定的位數(shù)。(右邊低位的數(shù)值被移出并丟棄,左邊高位空出的位置用0補齊)

(6)按位左移運算符
按位左移運算符(<<)將給定的值的二進(jìn)制數(shù)的所有位左移指定的位數(shù)。(左邊高位的數(shù)值被移出并丟棄,右邊低位空出的位置用0補齊)

到此這篇關(guān)于MySQL運算符使用方法全解析的文章就介紹到這了,更多相關(guān)mysql運算符內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
FROM_UNIXTIME 格式化MYSQL時間戳函數(shù)
對MYSQL沒有進(jìn)行過深入的研究,基礎(chǔ)知識匱乏,一遇到問題只能手冊,看來要把MYSQL的學(xué)習(xí)安排進(jìn)時間表了。2011-04-04
update.where無索引導(dǎo)致MySQL死鎖問題解決
這篇文章主要為大家介紹了update.where無索引導(dǎo)致MySQL死鎖問題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11
Mysql數(shù)據(jù)表中的蠕蟲復(fù)制使用方法
在本文中我們給大家分享了關(guān)于怎么使用Mysql數(shù)據(jù)表中的蠕蟲復(fù)制的相關(guān)知識點,有興趣的朋友們學(xué)習(xí)下。2019-02-02
Mysql最新版本的數(shù)據(jù)庫安裝教程(5.7)
這篇文章主要為大家詳細(xì)介紹了Mysql最新版本的數(shù)據(jù)庫安裝教程,分享了Mysql 5.7安裝配置方法,感興趣的小伙伴們可以參考一下2016-07-07
MySQL批量導(dǎo)入Excel數(shù)據(jù)(超詳細(xì))
這篇文章主要介紹了MySQL批量導(dǎo)入Excel數(shù)據(jù)(超詳細(xì)),文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,感興趣的小伙伴可以參考一下,希望對你的學(xué)習(xí)有所幫助2022-08-08
mysql中的delete,drop和truncate有什么區(qū)別
這篇文章主要介紹了mysql中的delete,drop和truncate有什么區(qū)別,三者的用法和使用場景又完全不同,接下來我們來看看具體的區(qū)別吧,希望對你的學(xué)習(xí)有所幫助2022-06-06

