MySQL條件查詢語句常用操作全面匯總
顧名思義, 條件查詢就是使用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)文章
vs如何讀取mysql中的數(shù)據(jù)并解決中文亂碼問題
這篇文章主要介紹了vs如何讀取mysql中的數(shù)據(jù)并解決中文亂碼問題,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-09-09MySQL關(guān)于字符串中數(shù)字排序的問題分析
這篇文章主要介紹了MySQL關(guān)于字符串中數(shù)字排序的問題,結(jié)合實(shí)例形式分析了mysql按照數(shù)值排序的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2016-06-06mysql中根據(jù)已有的表來創(chuàng)建新表的三種方式(最新推薦)
這篇文章主要介紹了mysql中根據(jù)已有的表來創(chuàng)建新表的三種方式,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-07-07MySQL存儲引擎MyISAM與InnoDB的9點(diǎn)區(qū)別
這篇文章主要介紹了MySQL存儲引擎MyISAM與InnoDB的9點(diǎn)區(qū)別,寫給有選擇困難癥的同學(xué),需要的朋友可以參考下2014-08-08MySQL查詢和篩選存儲的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