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

mysql學(xué)習(xí)筆記之完整的select語句用法實(shí)例詳解

 更新時(shí)間:2020年04月10日 11:54:40   作者:隨風(fēng)行云  
這篇文章主要介紹了mysql學(xué)習(xí)筆記之完整的select語句用法,結(jié)合實(shí)例形式詳細(xì)分析了mysql select語句各種常見參數(shù)、使用方法及操作注意事項(xiàng),需要的朋友可以參考下

本文實(shí)例講述了mysql學(xué)習(xí)筆記之完整的select語句用法。分享給大家供大家參考,具體如下:

本文內(nèi)容:

  • 完整語法
  • 去重選項(xiàng)
  • 字段別名
  • 數(shù)據(jù)源
  • where
  • group by
  • having
  • order by
  • limit

首發(fā)日期:2018-04-11


完整語法:

先給一下完整的語法,后面將逐一來講解。

基礎(chǔ)語法:select 字段列表 from 數(shù)據(jù)源;

完整語法:select 去重選項(xiàng) 字段列表 [as 字段別名] from 數(shù)據(jù)源 [where子句] [group by 子句] [having子句] [order by 子句] [limit子句];


去重選項(xiàng)::

  • 去重選項(xiàng)就是是否對(duì)結(jié)果中完全相同的記錄(所有字段數(shù)據(jù)都相同)進(jìn)行去重:
    • all:不去重
    • distinct:去重
  • 語法:select 去重選項(xiàng) 字段列表 from 表名;

示例:

去重前:image ,去重后image

create table student(name varchar(15),gender varchar(15));
insert into student(name,gender) values("lilei","male");
insert into student(name,gender) values("lilei","male");
select * from student;
select distinct * from student;

補(bǔ)充:

  • 注意:去重針對(duì)的是查詢出來的記錄,而不是存儲(chǔ)在表中的記錄。如果說僅僅查詢的是某些字段,那么去重針對(duì)的是這些字段。

字段別名:

  • 字段別名是給查詢結(jié)果中的字段另起一個(gè)名字
  • 字段別名只會(huì)在當(dāng)次查詢結(jié)果中生效。
  • 字段別名一般都是輔助了解字段意義(比如我們定義的名字是name,我們希望返回給用戶的結(jié)果顯示成姓名)、簡寫字段名
  • 語法:select 字段 as 字段別名 from 表名;

示例:

使用前:image,使用后image

create table student(name varchar(15),gender varchar(15));
insert into student(name,gender) values("lilei","male");
insert into student(name,gender) values("lilei","male");
select * from student;
select name as "姓名",gender as "性別" from student;

數(shù)據(jù)源:

  • 事實(shí)上,查詢的來源可以不是“表名”,只需是一個(gè)二維表即可。那么數(shù)據(jù)來源可以是一個(gè)select結(jié)果。
  • 數(shù)據(jù)源可以是單表數(shù)據(jù)源,多表數(shù)據(jù)源,以及查詢語句
    • 單表:select 字段列表 from 表名;
    • 多表: select 字段列表 from 表名1,表名2,…; 【多表查詢時(shí)是將每個(gè)表中的x條記錄與另一個(gè)表y條記錄組成結(jié)果,組成的結(jié)果的記錄條數(shù)為x*y】【可以稱為笛卡爾積】
      • image
    • 查詢語句:select 字段列表 fromr (select語句) as 表別名;【這是將一個(gè)查詢結(jié)果作為一個(gè)查詢的目標(biāo)二維表,需要將查詢結(jié)果定義成一個(gè)表別名才能作為數(shù)據(jù)源】
    • -- 示例
      select name from (select * from student) as d;

where子句:

  • where子句是用于篩選符合條件的結(jié)果的。

where幾種語法:

  • 基于值:
    • = : where 字段 =值  ;查找出對(duì)應(yīng)字段等于對(duì)應(yīng)值的記錄。(相似的,<是小于對(duì)應(yīng)值,<=是小于等于對(duì)應(yīng)值,>是大于對(duì)應(yīng)值,>=是大于等于對(duì)應(yīng)值,!=是不等于),例如:where name = 'lilei'
    • like:where 字段 like 值 ;功能與 = 相似 ,但可以使用模糊匹配來查找結(jié)果。例如:where name like 'li%'
  • 基于值的范圍:
    • in: where 字段 in 范圍;查找出對(duì)應(yīng)字段的值在所指定范圍的記錄。例如:where age in (18,19,20)
    • not in : where 字段 not in 范圍;查找出對(duì)應(yīng)字段的值不在所指定范圍的記錄。例如:where age not in (18,19,20)
    • between x and y :where 字段 between x and y;查找出對(duì)應(yīng)字段的值在閉區(qū)間[x,y]范圍的記錄。例如:where age between 18 and 20。
  • 條件復(fù)合:
    • or : where 條件1 or 條件2… ; 查找出符合條件1或符合條件2的記錄。
    • and:  where 條件1 and 條件2… ; 查找出符合條件1并且符合條件2的記錄。
    • not : where not 條件1 ;查找出不符合條件的所有記錄。
    • &&的功能與and相同;||與or功能類似,!與not 功能類似。

補(bǔ)充:

  • where是從磁盤中獲取數(shù)據(jù)的時(shí)候就進(jìn)行篩選的。所以某些在內(nèi)存是才有的東西where無法使用。(字段別名什么的是本來不是“磁盤中的數(shù)據(jù)”(是在內(nèi)存這中運(yùn)行時(shí)才定義的),所以where無法使用,一般都依靠having來篩選).
select name as n ,gender from student where name ="lilei";
-- select name as n ,gender from student where n ="lilei"; --報(bào)錯(cuò)
select name as n ,gender from student having n ="lilei";

group by 子句:

    • group by 可以將查詢結(jié)果依據(jù)字段來將結(jié)果分組。
    • 語法:select 字段列表 from 表名 group by 字段;
      • 【字段可以有多個(gè),實(shí)際就是二次分組】image
-- 示例
select name,gender,count(name) as "組員" from student as d group by name;
select name,gender,count(name) as "組員" from student as d group by name,gender;

補(bǔ)充:

  • 實(shí)際上,group by 的作用主要是統(tǒng)計(jì)(使用情景很多,比如說統(tǒng)計(jì)某人的總分?jǐn)?shù),學(xué)生中女性的數(shù)量。。),所以一般會(huì)配合一些統(tǒng)計(jì)函數(shù)來使用:
    • count(x):統(tǒng)計(jì)每組的記錄數(shù),x是*時(shí)代表記錄數(shù),為字段名時(shí)代表統(tǒng)計(jì)字段數(shù)據(jù)數(shù)(除去NULL)
    • max(x):統(tǒng)計(jì)最大值,x是字段名
    • min(x):統(tǒng)計(jì)最小值,x是字段名
    • avg(x):統(tǒng)計(jì)平均值,x是字段名
    • sum(x):統(tǒng)計(jì)總和,x是字段名
  • group by 字段 后面還可以跟上asc或desc,代表分組后是否根據(jù)字段排序。

having子句:

    • having功能與where類似,不過having的條件判斷發(fā)生在數(shù)據(jù)在內(nèi)存中時(shí),所以可以使用在內(nèi)存中才發(fā)生的數(shù)據(jù),如“分組”,“字段別名”等。
    • 語法:select 字段列表 from 表名 having 條件;【操作符之類的可以參考where的,增加的只是一些“內(nèi)存”中的篩選條件】
-- 示例
select name as n ,gender from student having n ="lilei";
select name,gender,count(*) as "組員" from student as d group by name,gender having count(*) >2 ;-- 這里只顯示記錄數(shù)>2的分組

order by 子句:

  • order by 可以使查詢結(jié)果按照某個(gè)字段來排序
  • 語法:select 字段列表 from 表名 order by 字段 [asc|desc];
    • 字段可以有多個(gè),從左到右,后面的排序基于前面的,(比如:先按name排序,再按gender排序,后面的gender排序是針對(duì)前面name排序時(shí)name相同的數(shù)據(jù))
    • asc代表排序是遞增的
    • desc代表是遞減的
    • 也可以指定某個(gè)字段的排序方法,比如第一個(gè)字段遞增,第二個(gè)遞減。只需要在每個(gè)字段后面加asc或desc即可(雖然默認(rèn)不加是遞增,但還是加上更清晰明確)。
-- 示例
select * from student order by name;
select * from student order by name,gender;
select * from student order by name asc,gender desc;

limit子句:

  • limit是用來限制結(jié)果數(shù)量的。與where\having等配合使用時(shí),可以限制匹配出的結(jié)果。但凡是涉及數(shù)量的時(shí)候都可以使用limit(這里只是強(qiáng)調(diào)limit的作用,不要過度理解)
  • 語法:select 字段列表 from 表名 limit [offset,] count;
    • count是數(shù)量
    • offset是起始位置,offset從0開始,可以說是每條記錄的索引號(hào)
-- 示例
select * from student limit 1;
select * from student limit 3,1;
select * from student where name ="lilei" limit 1;
select * from student where name ="lilei" limit 3,1;

更多關(guān)于MySQL相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《MySQL查詢技巧大全》、《MySQL事務(wù)操作技巧匯總》、《MySQL存儲(chǔ)過程技巧大全》、《MySQL數(shù)據(jù)庫鎖相關(guān)技巧匯總》及《MySQL常用函數(shù)大匯總

希望本文所述對(duì)大家MySQL數(shù)據(jù)庫計(jì)有所幫助。

相關(guān)文章

  • 一文了解MYSQL三大范式和表約束

    一文了解MYSQL三大范式和表約束

    范式是"符合某一種級(jí)別的關(guān)系模式的集合,表示一個(gè)關(guān)系內(nèi)部各屬性之間的聯(lián)系的合理化程度",下面這篇文章主要給大家介紹了關(guān)于MYSQL三大范式和表約束的相關(guān)資料,需要的朋友可以參考下
    2022-04-04
  • Eclipse與MySQL數(shù)據(jù)庫的連接教程(已實(shí)操)

    Eclipse與MySQL數(shù)據(jù)庫的連接教程(已實(shí)操)

    用eclipse編寫的好的代碼,我們怎么才能連接到數(shù)據(jù)庫呢?下面這篇文章主要給大家介紹了關(guān)于Eclipse與MySQL數(shù)據(jù)庫連接的相關(guān)資料,下面的操作是經(jīng)本人驗(yàn)證,確實(shí)可行,需要的朋友可以參考下
    2023-05-05
  • MySQL 權(quán)限控制詳解

    MySQL 權(quán)限控制詳解

    這篇文章主要介紹了MySQL 權(quán)限控制詳解的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用MySQL,感興趣的朋友可以了解下
    2021-03-03
  • RPM方式安裝MySQL5.6源碼

    RPM方式安裝MySQL5.6源碼

    這篇文章主要為大家分享了RPM方式安裝MySQL5.6源碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-10-10
  • MYSQL索引無效和索引有效的詳細(xì)介紹

    MYSQL索引無效和索引有效的詳細(xì)介紹

    MYSQL索引無效和索引有效的詳細(xì)介紹,需要的朋友可以參考一下
    2013-05-05
  • MySQL報(bào)錯(cuò) table “xxx” doesn‘t exit的解決

    MySQL報(bào)錯(cuò) table “xxx” doesn‘t exit的解決

    本文主要介紹了MySQL報(bào)錯(cuò) table “xxx” doesn‘t exit的解決,主要原因是英文字母大小寫敏感導(dǎo)致,下面就來介紹一下解決方法,感興趣的可以了解一下
    2023-10-10
  • mysql 表空間及索引的查看方法

    mysql 表空間及索引的查看方法

    mysql 表空間及索引的查看方法,需要的朋友可以參考下。
    2011-07-07
  • MySQL對(duì)中文進(jìn)行排序詳解及實(shí)例

    MySQL對(duì)中文進(jìn)行排序詳解及實(shí)例

    這篇文章主要介紹了MySQL對(duì)中文進(jìn)行排序詳解及實(shí)例的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • 使用limit,offset分頁場景時(shí)為什么會(huì)慢

    使用limit,offset分頁場景時(shí)為什么會(huì)慢

    這篇文章主要介紹了使用limit,offset分頁場景時(shí)為什么會(huì)慢,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • 解析MySQL索引的作用

    解析MySQL索引的作用

    這篇文章主要為大家詳細(xì)介紹了MySQL索引的作用,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03

最新評(píng)論