mysql常見的運算符及使用

来源:http://www.cnblogs.com/doctorJoe/archive/2016/03/30/5338048.html
-Advertisement-
Play Games

mysql中有4類運算符,它們是: 算術運算符 比較運算符 邏輯運算符 位操作運算符 算術操作符 算術操作符是SQL中最基本的操作運算符,主要有一下幾種運算符: +(加)、 -(減)、 *(乘)、 /(除)、 %(求餘或者模) 算術操作符測試案例: 創建表tmp14,定義數據類型為INT的欄位num ...



mysql中有4類運算符,它們是:

  • 算術運算符
  • 比較運算符
  • 邏輯運算符
  • 位操作運算符
  • 算術操作符

算術操作符是SQL中最基本的操作運算符,主要有一下幾種運算符:

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

算術操作符測試案例:

創建表tmp14,定義數據類型為INT的欄位num,插入值64,對num值進行算術運算:

首先創建表tmp14,輸入語句如下:

CREATE TABLE tmp14 ( num INT);

向欄位num插入數據64:

INSERT INTO tmp14 value(64);

接下來,對num值進行加法和減法運算:

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

clip_image001

由計算結果可以看到,可以對num欄位的值進行加法和減法的運算,而且由於’+’和’–’的優先順序相同,因此先加後減,或者先減後加之後的結果是相同的。

對tmp14表中的num進行乘法、除法運算。

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

clip_image002

由計算結果可以看到,對num進行除法運算時候,由於64無法被3整除,因此MySQL對num/3求商的結果保存到了小數點後面四位,結果為21.3333;64除以3的餘數為1,因此取餘運算num%3的結果為1。

在數學運算時,除數為0的除法是沒有意義的,因此除法運算中的除數不能為0,如果被0除,則返回結果為NULL。

clip_image003

由計算結果可以看到,對num進行除法求商或者求餘運算的結果均為NULL。

  • 比較運算符

一個比較運算符的結果總是1,0或者是NULL。MySQL中的比較運算符有:

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

使用‘=’進行相等判斷,SQL語句如下:

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

clip_image004

使用’<=>’進行相等的判斷,SQL語句如下:

clip_image005

由結果可以看到,’<=>’在執行比較操作時和’=’的作用是相似的,唯一的區別是’<=>’可以用來對NULL進行判斷,兩者都為NULL時返回值為1。

不等於運算符 <>或者 !=

‘<>’或者’!=’用於判斷數字、字元串、表達式不相等的判斷。如果不相等,返回值為1;否則返回值為0。這兩個運算符不能用於判斷空值NULL。

使用’<>’和’!=’進行不相等的判斷,SQL語句如下:

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

clip_image006

由結果可以看到,兩個不等於運算符作用相同,都可以進行數字、字元串、表達式的比較判斷。

使用’<=’進行比較判斷,SQL語句如下:

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

clip_image007

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

使用’<’進行比較判斷,SQL語句如下:

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

clip_image008

使用’>=’進行比較判斷,SQL語句如下:

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

clip_image009

使用’>’進行比較判斷,SQL語句如下:

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

clip_image010

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

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

clip_image011

使用BETWEEN AND 進行值區間判斷,輸入SQL語句如下:

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

clip_image012

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

clip_image013

使用LEAST運算符進行大小判斷,SQL語句如下:

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

clip_image014

使用GREATEST運算符進行大小判斷,SQL語句如下:

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

clip_image015

使用IN、NOT IN運算符進行判斷,SQL語句如下:

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

clip_image016

存在NULL值時的IN查詢,SQL語句如下:

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

clip_image017

使用運算符LIKE進行字元串匹配運算,SQL語句如下:

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

clip_image018

使用運算符REGEXP進行字元串匹配運算,SQL語句如下:

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

clip_image019

  • 邏輯運算符

邏輯運算符的求值所得結果均為TRUE、FALSE或NULL。

邏輯運算符有:

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

使用非運算符“NOT”和“!”進行邏輯判斷,SQL語句如下:

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

clip_image020

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

clip_image021

使用與運算符“AND”和“&&”進行邏輯判斷,SQL語句如下:

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

clip_image022

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

clip_image023

使用或運算符“OR”和“||”進行邏輯判斷,SQL語句如下:

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

clip_image024

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

clip_image025

使用異或運算符“XOR”進行邏輯判斷,SQL語句如下:

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

執行上面的語句,結果如下。

clip_image026

  • 位運算符

位運算符是用來對二進位位元組中的位進行測試、移位或者測試處理。位運算符有:

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

使用位或運算符進行運算,SQL語句如下:

SELECT 10 | 15, 9 | 4 | 2;

clip_image027

使用位與運算符進行運算,SQL語句如下:

SELECT 10 & 15, 9 &4& 2;

clip_image028

使用位異或運算符進行運算,SQL語句如下:

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

clip_image029

使用位左移運算符進行運算,SQL語句如下:

SELECT 1<<2, 4<<2;

clip_image030

使用位右移運算符進行運算,SQL語句如下:

SELECT 1>>1, 16>>2;

clip_image031

使用位取反運算符進行運算,SQL語句如下:

SELECT 5 & ~1;

clip_image032


運算符的優先順序

  • 運算的優先順序決定了不同的運算符在表達式中計算的先後順序。
  • 級別高的運算符先進行計算,如果級別相同,MySQL按表達式的順序從左到右依次計算。當然,在無法確定優先順序的情況下,可以使用圓括弧“()”來改變優先順序。

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 今天一大清早去面試, 公司距離我家還挺近的, 花了一個小時走著去, 也順路印下簡歷, 理理思路, 到了公司面試官什麼的都不錯, 還給我講了很多知識, 收貨也是滿滿的, 總結下今天都遇到了哪些問題, 調整調整狀態. 1, 當需要自定義tabbar的item的數量可變時怎麼做的 這裡原本是想說自定義ta ...
  • - (void)initActionSheet { UIActionSheet *actionSheet = [[UIActionSheet alloc] initWithTitle:nil delegate:self cancelButtonTitle:@"取消" destructiveButto ...
  • Could not find Developer Disk Image 這是由於真機系統過高或者過低,Xcode中沒有匹配的配置包文件,我們可以通過這個路徑進入配置包的存放目錄: /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneO ...
  • 經過兩篇的介紹我想對RunLoop應該有了簡單的瞭解,至少不至於一無所知。 在這篇我想對“CFRunLoopObserverRef”做一下簡單的補充。 在補充之前先說一下。 在現在的開發中已經很少見到ARC了。 但是那是對與OC對象的。 CFRunLoopObserverRef屬於CF (Core ...
  • 偉大的設計來源於一致性和細緻化,而其實只要有足夠的紀律,每個團隊都可以實現這一點。 品牌(源碼:http://www.jinhusns.com/Products/Download/?type=xcj) 品 牌是應用設計的基石。它回答了“用戶使用應用時應該獲得何等感受”這個問題。首先,你應該確定你的主 ...
  • 一,代碼。 AppDelegate.h AppDelegate.m ...
  • 上一篇我們說了runloop 的幾種模式,那麼我們在模式中又要做些什麼呢??? 模式中有三個模塊: 事件源(輸入源) Source Source: 按照官方文檔分類 Port-Based Custom Input Cocoa Perform Selector 按照函數調用棧,Source的分類 So ...
  • 對於DBA來說,備份和刷新簡歷是最重要的兩項工作,如果發生故障後,發現備份也不可用,那麼刷新簡歷的重要性就顯現出來,哇咔咔!當然備份是DBA最重要的事情(沒有之一),在有條件的情況下,我們應該在多個伺服器上保留多份完備和日誌備份,甚至某些公司會要求將完備數據保留到磁帶或超大存儲上,以保證可以恢復很久 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...