欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL條件查詢語句常用操作全面匯總

 更新時(shí)間:2022年04月27日 15:16:35   作者:羨羨ˇ  
當(dāng)用戶查看表格的大量數(shù)據(jù)是,由于數(shù)據(jù)量過于巨大會導(dǎo)致很難獲取到需要的數(shù)據(jù),在這時(shí),就需要一個(gè)方法,一個(gè)可以通過用戶輸入獲取到用戶需要的數(shù)據(jù)并回填入表格,這就是條件查詢的作用

顧名思義, 條件查詢就是使用where字句 , 將滿足條件的數(shù)據(jù)篩選出來

語法 :

select < 結(jié)果 > from < 表名 > where < 條件 >

這里我們以t_user表為例

-- 查詢性別為男的信息
SELECT * FROM t_user WHERE sex='男'
-- 查詢性別不為男的信息
SELECT * FROM t_user WHERE NOT sex='男'
-- 查詢性別為男并且年齡為20的信息
SELECT * FROM t_user WHERE sex='男' AND age=20
-- 查詢性別為男或者年齡為20的信息
SELECT * FROM t_user WHERE sex='男' OR age=20

模糊查詢

LIKE

是否匹配于一個(gè)模式 一般和通配符搭配使用,可以判斷字符型數(shù)值或數(shù)值型.    

通配符: % 任意多個(gè)字符,包含 0 個(gè)字符 _ 任意單個(gè)字符

我們知道, 在實(shí)際查詢中, 往往我們只需要大致的信息, 就能查到我們需要的結(jié)果(例如淘寶搜索商品等) , 而這就需要到了模糊查詢 ,例 :

-- _下劃線一次匹配一個(gè)字符
-- %一次可以匹配0個(gè)或者多個(gè)字符
SELECT * FROM t_user WHERE NAME LIKE '_李_'
SELECT * FROM t_user WHERE NAME LIKE 'b__'
SELECT * FROM t_user WHERE NAME LIKE 'b%'

上述第三條sql查詢結(jié)果如下 : 

between and 兩者之間 , 包含臨界值;

in 判斷某字段的值是否屬于 in 列表中的某一項(xiàng)

IS NULL (為空的)或 IS NOT NULL (不為空的)

-- 查詢體重在100和130之間的信息,包括100和130
SELECT * FROM t_user WHERE weight BETWEEN 100 AND 130
-- 查詢體重是100或者110的信息
SELECT * FROM t_user WHERE weight IN(100,110)
-- 查詢生日為null或者不為null的信息
SELECT * FROM t_user WHERE birthday IS NULL
SELECT * FROM t_user WHERE birthday IS NOT NULL

這里需要注意, 我們?nèi)绻胣ull 來作為where的查詢條件時(shí) ,是不能寫成下面這樣

-- SELECT * FROM t_user WHERE birthday=NULL

這樣是查詢不到結(jié)果的, 這里我們需要使用 is null

union

使用 union 或者 union all 會把兩條sql語句的查詢結(jié)果合并

當(dāng)使用union 時(shí),mysql 會把結(jié)果集中重復(fù)的記錄刪掉,而使用union all , mysql 會把所有的記錄返回,且效率高于union 。

SELECT * FROM t_user WHERE age=20 
UNION 
SELECT * FROM t_user WHERE sex='男'

查詢結(jié)果 : 

SELECT * FROM t_user WHERE age=20 
UNION ALL
SELECT * FROM t_user WHERE sex='男'

 查詢結(jié)果 : 

排序 

查詢結(jié)果排序 , 使用 ORDER BY 子句排序 order by 排序列 ASC/DESC

asc 代表的是升序, desc 代表的是降序,如果不寫,默認(rèn)是升序

order by 子句中可以支持單個(gè)字段、多個(gè)字段、表達(dá)式、函數(shù)、別名

-- 按體重升序排列
SELECT * FROM t_user ORDER BY weight ASC
-- 按體重降序排列
SELECT * FROM t_user ORDER BY weight DESC
-- 如果體重相等,就按照學(xué)號來排,升序
SELECT * FROM t_user ORDER BY weight ASC, number ASC

數(shù)量限制

limit 子句:對查詢的顯示結(jié)果限制數(shù)目 (sql 語句最末尾位置 )

在實(shí)際查詢中, 數(shù)據(jù)庫內(nèi)會存放大量的數(shù)據(jù), 所以我們會對查詢的數(shù)量進(jìn)行控制,這時(shí)就需要limit

-- 從第一條數(shù)據(jù)開始查詢2條數(shù)據(jù)(不包括第一條數(shù)據(jù))
SELECT * FROM t_user LIMIT 1,2

limit  后第一位數(shù)字是指: 開始查詢的位置

第二位數(shù)字是指: 查詢的數(shù)據(jù)條數(shù)

分組

group by 子句 : 對查詢的信息分組

having 子句 : 對分組后的結(jié)果集再進(jìn)行篩選

-- 通過sex分組
-- 這里select后跟的必須是group by后的字段或者分組函數(shù)
SELECT sex,AVG(weight) FROM t_user GROUP BY sex
SELECT sex,AVG(weight) FROM t_user GROUP BY sex HAVING sex='女'

這里需要注意的是: 

查詢列表比較特殊,要求是分組函數(shù)和group by后出現(xiàn)的字段 

分組前篩選 原始表    group by 子句的前面         where

分組后篩選 分組后的結(jié)果集 group by 的后面    having

where 是分組前篩選, having是分組后篩選

綜合

在實(shí)際的開發(fā)過程中,這些字句都是連在一起使用的,并且有著一定的位置, 位置不對就會報(bào)錯(cuò),例:

SELECT sex,AVG (weight) w
FROM
  t_user
WHERE sex = '男'
GROUP BY sex
HAVING sex = '男'
ORDER BY w ASC
LIMIT 0, 1

子句的順序是有一定要求的

查詢結(jié)果 : 

到此這篇關(guān)于MySQL條件查詢語句常用操作全面匯總的文章就介紹到這了,更多相關(guān)MySQL條件查詢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • mysql數(shù)據(jù)存放的位置在哪

    mysql數(shù)據(jù)存放的位置在哪

    在本篇文章里小編給大家分享的是關(guān)于mysql數(shù)據(jù)存放的位置及相關(guān)知識點(diǎn)內(nèi)容,需要的朋友們可以參考下。
    2020-07-07
  • SQL字符串以及數(shù)字常用操作匯總

    SQL字符串以及數(shù)字常用操作匯總

    本篇文章是對SQL字符串以及數(shù)字的常用操作進(jìn)行了詳細(xì)的總結(jié)與分析,需要的朋友參考下
    2013-06-06
  • vs如何讀取mysql中的數(shù)據(jù)并解決中文亂碼問題

    vs如何讀取mysql中的數(shù)據(jù)并解決中文亂碼問題

    這篇文章主要介紹了vs如何讀取mysql中的數(shù)據(jù)并解決中文亂碼問題,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-09-09
  • 詳解SUM函數(shù)在MySQL中的值處理原則

    詳解SUM函數(shù)在MySQL中的值處理原則

    在SQL中,SUM函數(shù)是用于計(jì)算指定字段的總和的聚合函數(shù),這篇文章將給大家詳細(xì)介紹了SUM函數(shù)在SQL中的值處理原則,文中有詳細(xì)的代碼示例供大家參考,具有一定的參考價(jià)值,需要的朋友可以參考下
    2023-12-12
  • Mysql中正則表達(dá)式Regexp常見用法及說明

    Mysql中正則表達(dá)式Regexp常見用法及說明

    這篇文章主要介紹了Mysql中正則表達(dá)式Regexp常見用法及說明,具有很好的參考價(jià)值,希望對大家有所幫助。
    2022-12-12
  • MySQL關(guān)于字符串中數(shù)字排序的問題分析

    MySQL關(guān)于字符串中數(shù)字排序的問題分析

    這篇文章主要介紹了MySQL關(guān)于字符串中數(shù)字排序的問題,結(jié)合實(shí)例形式分析了mysql按照數(shù)值排序的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2016-06-06
  • mysql中根據(jù)已有的表來創(chuàng)建新表的三種方式(最新推薦)

    mysql中根據(jù)已有的表來創(chuàng)建新表的三種方式(最新推薦)

    這篇文章主要介紹了mysql中根據(jù)已有的表來創(chuàng)建新表的三種方式,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-07-07
  • MySQL存儲引擎MyISAM與InnoDB的9點(diǎn)區(qū)別

    MySQL存儲引擎MyISAM與InnoDB的9點(diǎn)區(qū)別

    這篇文章主要介紹了MySQL存儲引擎MyISAM與InnoDB的9點(diǎn)區(qū)別,寫給有選擇困難癥的同學(xué),需要的朋友可以參考下
    2014-08-08
  • MySQL查詢和篩選存儲的JSON數(shù)據(jù)的操作方法

    MySQL查詢和篩選存儲的JSON數(shù)據(jù)的操作方法

    MySQL是常用的關(guān)系型數(shù)據(jù)庫管理系統(tǒng),為了支持非結(jié)構(gòu)化數(shù)據(jù)的存儲和查詢,MySQL引入了對JSON數(shù)據(jù)類型的支持,JSON是一種輕量級的數(shù)據(jù)交換格式,在現(xiàn)代應(yīng)用程序中得到了廣泛應(yīng)用,處理和存儲非結(jié)構(gòu)化數(shù)據(jù)變得越來越重要,本文給大家介紹mysql查詢JSON數(shù)據(jù)的相關(guān)知識,一起看看吧
    2024-01-01
  • Mysql varchar大小長度問題介紹

    Mysql varchar大小長度問題介紹

    如果被 varchar 超過上述的 b 規(guī)則,被強(qiáng)轉(zhuǎn)成 text 類型,則每個(gè)字段占用定義長度為 11 字節(jié),當(dāng)然這已經(jīng)不是 varchar 了
    2011-10-10

最新評論