mysql基本查詢
1.條件
使用 where 子句對表中的數據篩選,結果為true的行會出現在結果集中,語法如下:
select * from 表名 where 條件;
例:select * from students where id = 1;
where 後面支持多種條件運算符,進行條件的處理:
比較運算符;
邏輯運算符;
模糊查詢;
範圍查詢;
空判斷;
1.1.比較運算符
等於: =
大於: >
大於等於: >=
小於: <
小於等於: <=
不等於: != 或 <>
1.2.邏輯運算符
and or not
1.3.模糊查詢 like
% 表示任意多個任意字符
select * from students where name like "貝%";
_ 表示一個任意字符
select * from students where name like "貝_塔";
rlike "str" 表示字段中存在"str"字符
select * from students where name rlike "吉";
1.4.範圍查詢
in() 範圍
= any|some() 任意一個,等價 in
= all() 等於所有的
<> all() 不等於其中任何一項
2.排序
將查詢的結果進行排序 order by 字段名 asc(升序)|desc(降序) ,如果不寫默認升序
例:將未被刪除的學生按照id降序排序
select * from students where isdelete=0 order by id desc;
3.聚合函數
count() 統計數量 , max() 求最大值, min() 求最小值, sum() 求和, avg() 求平均值
例1:求所有學生數量
select count(*) from students;
例2:求學生中的最大年齡
select max(age) from students;
例3:求學生中的最小年齡
select min(age) from students;
例4:求所有學生的年齡總和
select sum(age) from students;
例5:求學生的平均年齡
select avg(age) from students;
4.分組
按照字段分組,表示此字段相同的數據會被放到一個組中分組後,分組的依據列會顯示在結果集中,
其他列不會顯示在結果集中可以對分組後的數據進行統計,做聚合運算。
select 列1,列2,聚合... from 表名 group by 列1,列2,列3... having 列1,...聚合...
例1:以性別分組查看分別有多少人
select gender,count(*) from students group by gender;
例2:查看男生人數
select gender,count(*) from students group by gender having gender="男";
對比 where 和 having :
where 是對from後面指定的表進行數據篩選,屬於對原始數據的篩選.
having 是對group by的結果進行篩選.
5.分頁
當數據量過大時,在一頁中查看數據是一件非常麻煩的事情
語法 select * from 表名 limit start,count
從start開始,獲取count條數據,start索引從0開始
例1:查詢前兩行男生的信息
select * from students where gender="男" limit 0,2;
例2:已知每頁顯示m條數據,當前顯示第n頁,求第n頁的數據
select * from students where isdelete=0 limit (n-1)*m,m;
6.連接查詢
當查詢結果的列來源於多張表時,需要將多張表連接成一個大的數據集,再選擇合適的列返回
mysql支持三種類型的連接查詢,分別為:
內連接查詢 inner join ...on :查詢的結果為兩個表匹配到的數據
右連接查詢 right outer join ...on :查詢的結果為兩個表匹配到的數據,右表特有的數據,對於左表中不存在的數據使用null填充
左連接查詢 left outer join ...on :查詢的結果為兩個表匹配到的數據,左表特有的數據,對於右表中不存在的數據使用null填充
例1:使用內連接查詢學生表和班級表
select * from students inner join classes on students.cls_id = classes.id;
例2:使用右連接查詢學生表和班級表
select * from students as s right outer join classes as c on s.cls_id=c.id;
例3:使用左連接查詢學生表和班級表
select * from students as s left outer join classes as c on s.cls_id=c.id;
7.子查詢
在一個 select 語句中,嵌入了另外一個 select 語句, 那麽被嵌入的 select 語句稱之為子查詢語句
主查詢和子查詢的關系:
子查詢是嵌入到主查詢中
子查詢是輔助主查詢的,要麽充當條件,要麽充當數據源
子查詢是可以獨立存在的語句,是一條完整的 select 語句
子查詢分類:
標量子查詢: 子查詢返回的結果是一個數據(一行一列)
列子查詢: 返回的結果是一列(一列多行)
行子查詢: 返回的結果是一行(一行多列)
表級子查詢: 返回的結果是多行多列
例:查詢班級裏大於平均年齡的學生數量
select count(*) from students where age > (select avg(age) from students);
總結
查詢的完整格式:
SELECT select_expr [,select_expr,...] [
FROM tb_name
[WHERE 條件判斷]
[GROUP BY {col_name | postion} [ASC | DESC], ...]
[HAVING WHERE 條件判斷]
[ORDER BY {col_name|expr|postion} [ASC | DESC], ...]
[ LIMIT {[offset,]rowcount | row_count OFFSET offset}]
完整的select語句:
select distinct *
from 表名
where ....
group by ... having ...
order by ...
limit start,count
mysql基本查詢