主頁 > 資料庫 > 單表查詢

單表查詢

2023-05-16 22:26:48 資料庫

第一章 簡單查詢

1.1、select陳述句

mysql 中查詢資料的基本陳述句是select陳述句,

語法:

select [distinct] 欄位1,欄位2,欄位3.....
from 表名
[where 條件運算式]
[group by 欄位名]
[having 條件運算式]
[order by 欄位名 [asc|desc]]
[limit 偏移量]

distinct:剔除重復資料

[]:可選項

[where 條件運算式] :用于條件判斷

[group by 欄位名] : 用于分組
[having 條件運算式] : 與 group by 連用,用于判斷
[order by 欄位名 [asc|desc]] : 排序,asc:默認的,升序;desc:降序
[limit ] : 分頁

順序按照上述語法執行,

1.2、查詢所有欄位

查詢所有欄位有兩種方式:

  • 通過 列出所有欄位名

    • 例如現在需要查詢 book 表中資料

    • select bid,bname,author
      from book;
      

  • 通過 *

    • 同樣查詢 book 表中資料

    • select * from book;
      

一般情況下,除非需要使用表中的所有欄位的資料,否則最好不要使用 * ,雖然可以節省輸入查詢陳述句的時間,但是由于獲取的資料多,會導致降低查詢效率

1.3、查詢指定欄位

語法:

select 需要的欄位名 from 表名;

例查詢 book 表中的書名 與 作者:

select author,bname from book;

第二章 條件查詢

由于資料庫中有大量的資料,很多時候需要根據需求來獲取指定的資料,或者對查詢的資料重新進行排列組合,這時就需要在查詢陳述句中添加條件來篩選,

語法:

select 欄位名.....
from 表名
where 條件判斷

where 中的條件判斷是指 select 陳述句中的查詢條件,查詢條件可以為如下示:

2.1、關系運算子

mysql 中常見的關系運算子如下:

關系運算子 說明 關系運算子 說明
= 等于 <= 小于等于
<> 不等于 >= 大于等于
!= 不等于 > 大于
< 小于

其中 <>!= 是等價的.

案例操作:

#查詢 sid 為 4 的學生姓名
select sname from score where sid=4;

其余操作類似,

2.2、in關鍵字

用于判斷某個欄位的值是否在指定集合中

語法:

select 欄位 from 表名 where 欄位名 [not] In (值1,值2,值3.....) 

[not] :可選引數,表示不在

案例操作:查詢 sid 為 1,2,4 的學生姓名

select sid,sname from score where sid in (1,2,4);

2.3、between and

between and 用于判斷某個欄位是否在指定范圍內

語法:

select *|欄位
from 表
where 欄位名 [not] between 值1 and 值2

值1:起始值

值2:結束值

相當于:[值1,值2]

案例操作:查詢 sid 在[2,5]的學生資訊

select sid,sname from score where sid between 2 and 5;

2.4、空值查詢

在資料庫中,有些列可能為空值,空值不是0,也不是空字串,在 mysql 使用 is null 來判斷欄位是否為空

語法:

select *|欄位
from 表
where 欄位名 is [not] null; 

2.5、distinct

用于剔除查詢結果中重復資料

語法:

select distinct 欄位
from 
where 

當 distinct 后面欄位有多個時,只有欄位值相同,才會被認為是重復的記錄,也就是說在多欄位下,欄位中需要有重復值,disinct才會生效,

2.6、like

模糊查詢,

當需要對字串進行不確定查詢使用

語法:

select *|欄位
from 表
where 欄位名 [not] like '匹配字串'; 

匹配字串可通過通配符來使用:

%:可以匹配任意多個字符

_ :只能匹配一個字符

例如:查詢姓名含有 a 的員工資訊

select * from emp where name like '%a%';

查詢姓名第二個為 a 的員工

select * from emp where name like '%_a%';

2.7、and 多條件查詢

用于連接兩個查詢條件

語法:

select *|欄位
from 表
where 條件運算式 1 and 條件運算式2 [and ...]; 

例如:查詢 sid 小于 4 且 成績為 大于 60的學生

select sname
from score
where sid < 4 and grade > 60;

2.8、or 多條件查詢

作用與 and 差不多,只不過條件滿足其一即可

語法:

select *|欄位
from 表
where 條件運算式 1 or 條件運算式2 [or ...]; 

例如:查詢學生表中名字以 h 開頭,或者性別為 女 或者 成績為 100 的學生

select id,name,grade,gender
from student
where name like 'h%' or gender = '女' or grade=100;

當 or 與 and 一起連用時,因為 and 優先級大于 or,所以會先 and 再 or

第三章 高級查詢

3.1、聚合函式

常見聚集函式有:

函式名稱 作用 函式名稱 作用
COUNT() 回傳總行數 MAX() 回傳某列的最大值
SUM() 回傳某列的和 MIN() 回傳某列的最小值
AVG() 回傳某列的平均值

可與 select 查詢結合使用

3.1.1、count()

可用來統計記錄的條數

語法:

select count( * | 某列) from 表名;

對于列我們可以通過 * 來代替所有列,

3.1.2、SUM()

求出表中某欄位所有值的總和,

語法:

select sum(欄位名) from 表名;

其余操作與上述相同,

3.2、排序

當對表中的資料查詢后結果可能是無序的或排序不是需求的理想結果,這時可使用 order by 來進行查詢結果排序,

語法:

select 欄位名1,欄位名2.........
from 表名
order by 欄位1 [ASC|DESC],欄位2 [asc|desc].......

asc:默認的,升序

desc:降序

3.3、分組查詢

在對表進行統計時,需要按照一定的類別來進行統計,這時可通過 group by 來進行分組.

語法:

select 欄位名1,欄位名2.........
from 表名
group by 欄位1 ,欄位2 .......
[having 條件判斷]

having:對分組后的內容進行過濾,常與 group by 一起使用

如果 查詢欄位出現在 group by 后,卻沒有包含在聚合函式中,該欄位顯示的是分組后的第一條記錄的值,這樣可能導致查詢結果不符合預期,

3.4、limit

查詢資料時,可能會回傳多條記錄,而用戶需求可能只有其中部分,比如分頁功能,每頁顯示 10 條資訊,每次查詢就只需查詢出 10條記錄即可,

這時可使用 limit 來實作上述功能.

語法:

select 欄位名1,欄位名2.........
from 表名
limit 偏移量 記錄數;

偏移量:可選項,不指定,則默認為 0,當其值為 0 時:表示從查詢結果中的第一條記錄開始,當其值為 1 :表示從查詢結果中第二條開始,以此類推,

記錄數:表示回傳查詢的條數

第四章 別名

4.1、表別名

語法:

select 欄位名 from 表名 [as] 別名;

4.2、欄位別名

語法:

select 欄位名 [as] 別名 from 表名 [as] 別名;

轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/552638.html

標籤:其他

上一篇:PostgreSQL一站式插件推薦 -- pg_enterprise_views

下一篇:返回列表

標籤雲
其他(159156) Python(38143) JavaScript(25431) Java(18048) C(15227) 區塊鏈(8267) C#(7972) AI(7469) 爪哇(7425) MySQL(7191) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5871) 数组(5741) R(5409) Linux(5340) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4572) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2433) ASP.NET(2403) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) .NET技术(1975) 功能(1967) Web開發(1951) HtmlCss(1937) python-3.x(1918) C++(1917) 弹簧靴(1913) xml(1889) PostgreSQL(1878) .NETCore(1861) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • GPU虛擬機創建時間深度優化

    **?桔妹導讀:**GPU虛擬機實體創建速度慢是公有云面臨的普遍問題,由于通常情況下創建虛擬機屬于低頻操作而未引起業界的重視,實際生產中還是存在對GPU實體創建時間有苛刻要求的業務場景。本文將介紹滴滴云在解決該問題時的思路、方法、并展示最終的優化成果。 從公有云服務商那里購買過虛擬主機的資深用戶,一 ......

    uj5u.com 2020-09-10 06:09:13 more
  • 可編程網卡芯片在滴滴云網路的應用實踐

    **?桔妹導讀:**隨著云規模不斷擴大以及業務層面對延遲、帶寬的要求越來越高,采用DPDK 加速網路報文處理的方式在橫向縱向擴展都出現了局限性。可編程芯片成為業界熱點。本文主要講述了可編程網卡芯片在滴滴云網路中的應用實踐,遇到的問題、帶來的收益以及開源社區貢獻。 #1. 資料中心面臨的問題 隨著滴滴 ......

    uj5u.com 2020-09-10 06:10:21 more
  • 滴滴資料通道服務演進之路

    **?桔妹導讀:**滴滴資料通道引擎承載著全公司的資料同步,為下游實時和離線場景提供了必不可少的源資料。隨著任務量的不斷增加,資料通道的整體架構也隨之發生改變。本文介紹了滴滴資料通道的發展歷程,遇到的問題以及今后的規劃。 #1. 背景 資料,對于任何一家互聯網公司來說都是非常重要的資產,公司的大資料 ......

    uj5u.com 2020-09-10 06:11:05 more
  • 滴滴AI Labs斬獲國際機器翻譯大賽中譯英方向世界第三

    **桔妹導讀:**深耕人工智能領域,致力于探索AI讓出行更美好的滴滴AI Labs再次斬獲國際大獎,這次獲獎的專案是什么呢?一起來看看詳細報道吧! 近日,由國際計算語言學協會ACL(The Association for Computational Linguistics)舉辦的世界最具影響力的機器 ......

    uj5u.com 2020-09-10 06:11:29 more
  • MPP (Massively Parallel Processing)大規模并行處理

    1、什么是mpp? MPP (Massively Parallel Processing),即大規模并行處理,在資料庫非共享集群中,每個節點都有獨立的磁盤存盤系統和記憶體系統,業務資料根據資料庫模型和應用特點劃分到各個節點上,每臺資料節點通過專用網路或者商業通用網路互相連接,彼此協同計算,作為整體提供 ......

    uj5u.com 2020-09-10 06:11:41 more
  • 滴滴資料倉庫指標體系建設實踐

    **桔妹導讀:**指標體系是什么?如何使用OSM模型和AARRR模型搭建指標體系?如何統一流程、規范化、工具化管理指標體系?本文會對建設的方法論結合滴滴資料指標體系建設實踐進行解答分析。 #1. 什么是指標體系 ##1.1 指標體系定義 指標體系是將零散單點的具有相互聯系的指標,系統化的組織起來,通 ......

    uj5u.com 2020-09-10 06:12:52 more
  • 單表千萬行資料庫 LIKE 搜索優化手記

    我們經常在資料庫中使用 LIKE 運算子來完成對資料的模糊搜索,LIKE 運算子用于在 WHERE 子句中搜索列中的指定模式。 如果需要查找客戶表中所有姓氏是“張”的資料,可以使用下面的 SQL 陳述句: SELECT * FROM Customer WHERE Name LIKE '張%' 如果需要 ......

    uj5u.com 2020-09-10 06:13:25 more
  • 滴滴Ceph分布式存盤系統優化之鎖優化

    **桔妹導讀:**Ceph是國際知名的開源分布式存盤系統,在工業界和學術界都有著重要的影響。Ceph的架構和演算法設計發表在國際系統領域頂級會議OSDI、SOSP、SC等上。Ceph社區得到Red Hat、SUSE、Intel等大公司的大力支持。Ceph是國際云計算領域應用最廣泛的開源分布式存盤系統, ......

    uj5u.com 2020-09-10 06:14:51 more
  • es~通過ElasticsearchTemplate進行聚合~嵌套聚合

    之前寫過《es~通過ElasticsearchTemplate進行聚合操作》的文章,這一次主要寫一個嵌套的聚合,例如先對sex集合,再對desc聚合,最后再對age求和,共三層嵌套。 Aggregations的部分特性類似于SQL語言中的group by,avg,sum等函式,Aggregation ......

    uj5u.com 2020-09-10 06:14:59 more
  • 爬蟲日志監控 -- Elastc Stack(ELK)部署

    傻瓜式部署,只需替換IP與用戶 導讀: 現ELK四大組件分別為:Elasticsearch(核心)、logstash(處理)、filebeat(采集)、kibana(可視化) 下載均在https://www.elastic.co/cn/downloads/下tar包,各組件版本最好一致,配合fdm會 ......

    uj5u.com 2020-09-10 06:15:05 more
最新发布
  • 單表查詢

    第一章 簡單查詢 1.1、select陳述句 mysql 中查詢資料的基本陳述句是select陳述句。 語法: select [distinct] 欄位1,欄位2,欄位3..... from 表名 [where 條件運算式] [group by 欄位名] [having 條件運算式] [order by ......

    uj5u.com 2023-05-16 22:26:48 more
  • PostgreSQL一站式插件推薦 -- pg_enterprise_views

    近日發現PG官方插件串列中新收錄了一款插件 pg_enterprise_views,因為官方已經數年未添新的插件了很是新奇,找了臺設備測驗過后果斷上了生產,得空分享給大家。 該插件提供了數十張系統表及一個GUI工具,用以監控從作業系統到資料庫方方面面的性能情況,并支持對任意時段歷史資料的回溯,基本等 ......

    uj5u.com 2023-05-16 22:26:12 more
  • PostgreSQL一站式插件推薦 -- pg_enterprise_views

    近日發現PG官方插件串列中新收錄了一款插件 pg_enterprise_views,因為官方已經數年未添新的插件了很是新奇,找了臺設備測驗過后果斷上了生產,得空分享給大家。 該插件提供了數十張系統表及一個GUI工具,用以監控從作業系統到資料庫方方面面的性能情況,并支持對任意時段歷史資料的回溯,基本等 ......

    uj5u.com 2023-05-16 22:12:18 more
  • 單表查詢

    第一章 簡單查詢 1.1、select陳述句 mysql 中查詢資料的基本陳述句是select陳述句。 語法: select [distinct] 欄位1,欄位2,欄位3..... from 表名 [where 條件運算式] [group by 欄位名] [having 條件運算式] [order by ......

    uj5u.com 2023-05-16 22:10:09 more
  • hive 從入門到精通

    hive入門到精通 hive部署 啟動Hadoop # 啟動hadoop start-all.sh # 檢查hadoop行程 jps # 檢查各埠 netstat -aplnt | grep java 檢查MySQL是否啟動成功 ps -aux | grep mysql netstat -apln ......

    uj5u.com 2023-05-16 15:32:25 more
  • pg_enterprise_views偶然發現的PG神仙插件!

    一直從事資料庫相關的作業,對于PG而言最大的問題其實是在運維管理方面,其缺乏有效且直觀成體系的系統表,苦覓良久,今日在PG官網中發現了一款新收錄的免費插件,其提供了數十張系統表,內容涵蓋了從作業系統到資料庫的負載指標、等待事件、會話、客戶端、SQL、SQL執行計劃、超時鎖、長事務、資料庫物件、寫行程 ......

    uj5u.com 2023-05-16 15:32:13 more
  • MySQL 8.0不再擔心被垃圾SQL搞爆記憶體

    MySQL 8.0.28引入的新功能 MySQL 8.0.28開始,新增一個特性,支持監控統計并限制各個連接(會話)的記憶體消耗,避免大量用戶連接因為執行垃圾SQL消耗過多記憶體,造成可能被OOM kill的風險。 首先,需要先設定系統選項 global_connection_memory_tracki ......

    uj5u.com 2023-05-16 15:31:01 more
  • ClickHouse筆記: Ubuntu/Centos下的安裝, 配置和用戶管理

    ClickHouse 屬于 OLAP 資料庫, 與 OLTP (Transaction Process) 相比, 注重資料分析, 重點在查詢的性能. 在業務系統中, 往往使用 OLTP 資料庫做業務資料存盤, 用 OLAP 資料庫做查詢分析, 在一些場景下ClickHouse可以取代ES(Elast... ......

    uj5u.com 2023-05-16 15:30:55 more
  • Redis實戰解讀-初識Redis&Redis基本資料型別

    一.初識Redis
    1.什么是Redis
    ? Redis是一個速度非常快的非關系型資料庫(non-relational database),它可以存盤鍵(key)與五種不同型別的值的映射(mapping),可以將存盤在記憶體的鍵值對資料持久化到磁盤,可以使用復制特性來擴展讀性能,也可以采用客戶端分片來... ......

    uj5u.com 2023-05-16 15:30:43 more
  • 06~12-Esp8266物聯網芯片的使用(一)-part02/03-ESP8266開發環境、

    上一章主要作了芯片介紹,這一章主要作對開發環境的介紹。 認識Arduino Arduino是一款便捷靈活、方便上手的開源電子原型平臺。包含硬體(各種型號的Arduino板)和軟體(ArduinoIDE)。它構建于開放原始碼simple I/O介面版,并且具有使用類似Java、C語言的Processi ......

    uj5u.com 2023-05-16 15:30:35 more