1. 程式人生 > >mysql基本查詢

mysql基本查詢

like gen 條件 左連接 比較運算符 表示 平均值 內連接 order by

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基本查詢