日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

mysql常见的运算符及使用

發(fā)布時(shí)間:2025/3/15 数据库 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql常见的运算符及使用 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

mysql中有4類運(yùn)算符,它們是:

  • 算術(shù)運(yùn)算符
  • 比較運(yùn)算符
  • 邏輯運(yùn)算符
  • 位操作運(yùn)算符
  • 算術(shù)操作符

算術(shù)操作符是SQL中最基本的操作運(yùn)算符,主要有一下幾種運(yùn)算符:

+(加)、 -(減)、 *(乘)、 /(除)、 %(求余或者模)

算術(shù)操作符測(cè)試案例:

創(chuàng)建表tmp14,定義數(shù)據(jù)類型為INT的字段num,插入值64,對(duì)num值進(jìn)行算術(shù)運(yùn)算:

首先創(chuàng)建表tmp14,輸入語(yǔ)句如下:

CREATE TABLE tmp14 ( num INT);

向字段num插入數(shù)據(jù)64:

INSERT INTO tmp14 value(64);

接下來(lái),對(duì)num值進(jìn)行加法和減法運(yùn)算:

SELECT num, num+10, num-3+5, num+5-3, num+36.5 FROM tmp14;

由計(jì)算結(jié)果可以看到,可以對(duì)num字段的值進(jìn)行加法和減法的運(yùn)算,而且由于’+’和’–’的優(yōu)先級(jí)相同,因此先加后減,或者先減后加之后的結(jié)果是相同的。

對(duì)tmp14表中的num進(jìn)行乘法、除法運(yùn)算。

SELECT num, num *2, num /2, num/3, num%3 FROM tmp14;

由計(jì)算結(jié)果可以看到,對(duì)num進(jìn)行除法運(yùn)算時(shí)候,由于64無(wú)法被3整除,因此MySQL對(duì)num/3求商的結(jié)果保存到了小數(shù)點(diǎn)后面四位,結(jié)果為21.3333;64除以3的余數(shù)為1,因此取余運(yùn)算num%3的結(jié)果為1。

在數(shù)學(xué)運(yùn)算時(shí),除數(shù)為0的除法是沒(méi)有意義的,因此除法運(yùn)算中的除數(shù)不能為0,如果被0除,則返回結(jié)果為NULL。

由計(jì)算結(jié)果可以看到,對(duì)num進(jìn)行除法求商或者求余運(yùn)算的結(jié)果均為NULL。

  • 比較運(yùn)算符

一個(gè)比較運(yùn)算符的結(jié)果總是1,0或者是NULL。MySQL中的比較運(yùn)算符有:

=、<=>、<> (!=)、<=、>=、>、IS NULL、IS NOT NULL、LEAST、GREATEST、BETWEEN . . . AND. . . 、ISNULL、IN、NOT IN、LIKE、REGEXP

使用‘=’進(jìn)行相等判斷,SQL語(yǔ)句如下:

SELECT 1=0, '2'=2, 2=2,'0.02'=0, 'b'='b', (1+3) = (2+2),NULL=NULL;

使用’<=>’進(jìn)行相等的判斷,SQL語(yǔ)句如下:

由結(jié)果可以看到,’<=>’在執(zhí)行比較操作時(shí)和’=’的作用是相似的,唯一的區(qū)別是’<=>’可以用來(lái)對(duì)NULL進(jìn)行判斷,兩者都為NULL時(shí)返回值為1。

不等于運(yùn)算符 <>或者 !=

‘<>’或者’!=’用于判斷數(shù)字、字符串、表達(dá)式不相等的判斷。如果不相等,返回值為1;否則返回值為0。這兩個(gè)運(yùn)算符不能用于判斷空值NULL。

使用’<>’和’!=’進(jìn)行不相等的判斷,SQL語(yǔ)句如下:

SELECT 'good'<>'god', 1<>2, 4!=4, 5.5!=5, (1+3)!=(2+1),NULL<>NULL;

由結(jié)果可以看到,兩個(gè)不等于運(yùn)算符作用相同,都可以進(jìn)行數(shù)字、字符串、表達(dá)式的比較判斷。

使用’<=’進(jìn)行比較判斷,SQL語(yǔ)句如下:

SELECT 'good'<='god', 1<=2, 4<=4, 5.5<=5, (1+3) <= (2+1),NULL<=NULL;

由結(jié)果可以看到,左邊操作數(shù)小于或者等于右邊時(shí),返回值為1,例如:4<=4;當(dāng)左邊操作數(shù)大于右邊時(shí),返回值為0,例如:’good’第3個(gè)位置的’o’字符在字母表中的順序大于’god’中的第3個(gè)位置的’d’字符,因此返回值為0;同樣比較NULL值時(shí)返回NULL。

使用’<’進(jìn)行比較判斷,SQL語(yǔ)句如下:

SELECT 'good'<'god', 1<2, 4<4, 5.5<5, (1+3) < (2+1),NULL<NULL;

使用’>=’進(jìn)行比較判斷,SQL語(yǔ)句如下:

SELECT 'good'>='god', 1>=2, 4>=4, 5.5>=5, (1+3) >= (2+1),NULL>=NULL;

使用’>’進(jìn)行比較判斷,SQL語(yǔ)句如下:

SELECT 'good'>'god', 1>2, 4>4, 5.5>5, (1+3) > (2+1),NULL>NULL;

使用IS NULL、ISNULL和IS NOT NULL判斷NULL值和非NULL值,SQL語(yǔ)句如下:

SELECT NULL IS NULL, ISNULL(NULL),ISNULL(10), 10 IS NOT NULL;

使用BETWEEN AND 進(jìn)行值區(qū)間判斷,輸入SQL語(yǔ)句如下:

SELECT 4 BETWEEN 4 AND 6, 4 BETWEEN 4 AND 6,12 BETWEEN 9 AND 10;

SELECT 'x' BETWEEN 'f' AND 'g', 'b' BETWEEN 'a' AND 'c';

使用LEAST運(yùn)算符進(jìn)行大小判斷,SQL語(yǔ)句如下:

SELECT least(2,0), least(20.0,3.0,100.5), least('a','c','b'),least(10,NULL);

使用GREATEST運(yùn)算符進(jìn)行大小判斷,SQL語(yǔ)句如下:

SELECT greatest(2,0), greatest(20.0,3.0,100.5), greatest('a','c','b'),greatest(10,NULL);

使用IN、NOT IN運(yùn)算符進(jìn)行判斷,SQL語(yǔ)句如下:

SELECT 2 IN (1,3,5,'thks'), 'thks' IN (1,3,5,'thks');

存在NULL值時(shí)的IN查詢,SQL語(yǔ)句如下:

SELECT NULL IN (1,3,5,'thks'),10 IN (1,3,NULL,'thks');

使用運(yùn)算符LIKE進(jìn)行字符串匹配運(yùn)算,SQL語(yǔ)句如下:

SELECT 'stud' LIKE 'stud', 'stud' LIKE 'stu_','stud' LIKE '%d','stud' LIKE 't_ _ _', 's' LIKE NULL;

使用運(yùn)算符REGEXP進(jìn)行字符串匹配運(yùn)算,SQL語(yǔ)句如下:

SELECT 'ssky' REGEXP '^s', 'ssky' REGEXP 'y$', 'ssky' REGEXP '.sky', 'ssky' REGEXP '[ab]';

  • 邏輯運(yùn)算符

邏輯運(yùn)算符的求值所得結(jié)果均為T(mén)RUE、FALSE或NULL。

邏輯運(yùn)算符有:

  • NOT 或者 !
  • AND 或者 &&
  • OR 或者 ||
  • XOR(異或)

使用非運(yùn)算符“NOT”和“!”進(jìn)行邏輯判斷,SQL語(yǔ)句如下:

SELECT NOT 10, NOT (1-1), NOT -5, NOT NULL, NOT 1 + 1;

SELECT !10, !(1-1), !-5, ! NULL, ! 1 + 1;

使用與運(yùn)算符“AND”和“&&”進(jìn)行邏輯判斷,SQL語(yǔ)句如下:

SELECT 1 AND -1,1 AND 0,1 AND NULL, 0 AND NULL;

SELECT 1 && -1,1 && 0,1 && NULL, 0 && NULL;

使用或運(yùn)算符“OR”和“||”進(jìn)行邏輯判斷,SQL語(yǔ)句如下:

SELECT 1 OR -1 OR 0, 1 OR 2,1 OR NULL, 0 OR NULL, NULL OR NULL;

SELECT 1 || -1 || 0, 1 || 2,1 || NULL, 0 || NULL, NULL || NULL;

使用異或運(yùn)算符“XOR”進(jìn)行邏輯判斷,SQL語(yǔ)句如下:

SELECT 1 XOR 1, 0 XOR 0, 1 XOR 0, 1 XOR NULL, 1 XOR 1 XOR 1;

執(zhí)行上面的語(yǔ)句,結(jié)果如下。

  • 位運(yùn)算符

位運(yùn)算符是用來(lái)對(duì)二進(jìn)制字節(jié)中的位進(jìn)行測(cè)試、移位或者測(cè)試處理。位運(yùn)算符有:

  • 位或(|)
  • 位與(&)
  • 位異或(^ )
  • 位左移(<<)
  • 位右移(<<)
  • 位取反(~)

使用位或運(yùn)算符進(jìn)行運(yùn)算,SQL語(yǔ)句如下:

SELECT 10 | 15, 9 | 4 | 2;

使用位與運(yùn)算符進(jìn)行運(yùn)算,SQL語(yǔ)句如下:

SELECT 10 & 15, 9 &4& 2;

使用位異或運(yùn)算符進(jìn)行運(yùn)算,SQL語(yǔ)句如下:

SELECT 10 ^ 15, 1 ^0, 1 ^ 1;

使用位左移運(yùn)算符進(jìn)行運(yùn)算,SQL語(yǔ)句如下:

SELECT 1<<2, 4<<2;

使用位右移運(yùn)算符進(jìn)行運(yùn)算,SQL語(yǔ)句如下:

SELECT 1>>1, 16>>2;

使用位取反運(yùn)算符進(jìn)行運(yùn)算,SQL語(yǔ)句如下:

SELECT 5 & ~1;


運(yùn)算符的優(yōu)先級(jí)

  • 運(yùn)算的優(yōu)先級(jí)決定了不同的運(yùn)算符在表達(dá)式中計(jì)算的先后順序。
  • 級(jí)別高的運(yùn)算符先進(jìn)行計(jì)算,如果級(jí)別相同,MySQL按表達(dá)式的順序從左到右依次計(jì)算。當(dāng)然,在無(wú)法確定優(yōu)先級(jí)的情況下,可以使用圓括號(hào)“()”來(lái)改變優(yōu)先級(jí)。

轉(zhuǎn)載于:https://www.cnblogs.com/johnhery/p/10044956.html

新人創(chuàng)作打卡挑戰(zhàn)賽發(fā)博客就能抽獎(jiǎng)!定制產(chǎn)品紅包拿不停!

總結(jié)

以上是生活随笔為你收集整理的mysql常见的运算符及使用的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。