mysql/mariadb學習記錄——查詢

来源:https://www.cnblogs.com/joy9707/archive/2018/05/01/8975408.html
-Advertisement-
Play Games

連接查詢:同時設計兩個及以上的表的查詢 連接條件或連接謂詞:用來連接兩個表的條件一般格式: [<表名1>]<列名1> <比較運算符> [<表名2>]<列名2> [<表名1>]<列名1> between [<表名2>]<列名2> and [<表名2>]<列名3> 等值連接: 連接運算符為= 查詢每個學 ...


連接查詢:同時設計兩個及以上的表的查詢

連接條件或連接謂詞:用來連接兩個表的條件一般格式:

[<表名1>]<列名1> <比較運算符> [<表名2>]<列名2>

[<表名1>]<列名1> between [<表名2>]<列名2> and [<表名2>]<列名3>

等值連接:

連接運算符為=

查詢每個學生以及選修課程的情況

mysql> select student.*, sc.* from student,sc where student.sno=sc.sno;
+-------+--------+------+------+-------+-------+-----+-------+
| sno   | sname  | ssex | sage | sdept | sno   | cno | grade |
+-------+--------+------+------+-------+-------+-----+-------+
| 95001 | 李勇    | 男   |   20 | CS    | 95001 | 1   |    92 |
| 95001 | 李勇    | 男   |   20 | CS    | 95001 | 2   |    85 |
| 95001 | 李勇    | 男   |   20 | CS    | 95001 | 3   |    88 |
| 95002 | 劉晨    | 女   |   19 | IS    | 95002 | 2   |    90 |
| 95002 | 劉晨    | 女   |   19 | IS    | 95002 | 3   |    80 |
| 95004 | 張立    | 男   |   20 | IS    | 95004 | 2   |    65 |
| 95004 | 張立    | 男   |   20 | IS    | 95004 | 3   |  NULL |
| 95004 | 張立    | 男   |   20 | IS    | 95004 | 4   |  NULL |
| 95005 | 張三    | 男   |   23 | CS    | 95005 | 2   |    84 |
| 95005 | 張三    | 男   |   23 | CS    | 95005 | 4   |  NULL |
| 96001 | 劉軍    | 男   |   30 | IS    | 96001 | 1   |    87 |
| 96001 | 劉軍    | 男   |   30 | IS    | 96001 | 2   |    80 |
| 96001 | 劉軍    | 男   |   30 | IS    | 96001 | 3   |    90 |
| 96001 | 劉軍    | 男   |   30 | IS    | 96001 | 4   |    95 |
| 96001 | 劉軍    | 男   |   30 | IS    | 96001 | 5   |  NULL |
| 96001 | 劉軍    | 男   |   30 | IS    | 96001 | 6   |  NULL |
| 96001 | 劉軍    | 男   |   30 | IS    | 96001 | 7   |    86 |
| 97001 | 李四    | 男   |   26 | EN    | 97001 | 4   |  NULL |
| 97001 | 李四    | 男   |   26 | EN    | 97001 | 5   |  NULL |
+-------+--------+------+------+-------+-------+-----+-------+

 

自身連接:一個表與自己進行連接

需要給表起別名以示區別,且必須使用首碼

//查詢每門課的間接先修課
mysql> select first.cno,second.cpno from course first,course second where first.cpno=second.cno;
+-----+------+
| cno | cpno |
+-----+------+
| 3   | 5    |
| 1   | 7    |
| 4   | NULL |
| 7   | NULL |
| 5   | 6    |
+-----+------+
5 rows in set (0.05 sec)

//查詢沒門課先修課的名稱
mysql> select FIRST.cno,FIRST.cname,FIRST.cpno,SECOND.cname from course FIRST,course SECOND where FIRST.cpno=SECOND.cno;
+-----+--------------+------+--------------+
| cno | cname        | cpno | cname        |
+-----+--------------+------+--------------+
| 1   | 資料庫        | 5    | 數據結構      |
| 3   | 信息系統      | 1    | 資料庫        |
| 4   | 操作系統      | 6    | 數據處理      |
| 5   | 數據結構      | 7    | C語言        |
| 7   | C語言        | 6     | 數據處理      |
+-----+--------------+------+--------------+

多表連接:兩個以上的表進行連接

mysql> select student.sno,sname,cname,grade from student,sc,course where student.sno=sc.sno and sc.cno=course.cno;
+-------+--------+--------------+-------+
| sno   | sname  | cname        | grade |
+-------+--------+--------------+-------+
| 95001 | 李勇   | 資料庫       |    92 |
| 96001 | 劉軍   | 資料庫       |    87 |
| 95001 | 李勇   | 高等數學     |    85 |
| 95002 | 劉晨   | 高等數學     |    90 |
| 95004 | 張立   | 高等數學     |    65 |
| 95005 | 張三   | 高等數學     |    84 |
| 96001 | 劉軍   | 高等數學     |    80 |
| 95001 | 李勇   | 信息系統     |    88 |
| 95002 | 劉晨   | 信息系統     |    80 |
| 95004 | 張立   | 信息系統     |  NULL |
| 96001 | 劉軍   | 信息系統     |    90 |
| 95004 | 張立   | 操作系統     |  NULL |
| 95005 | 張三   | 操作系統     |  NULL |
| 96001 | 劉軍   | 操作系統     |    95 |
| 97001 | 李四   | 操作系統     |  NULL |
| 96001 | 劉軍   | 數據結構     |  NULL |
| 97001 | 李四   | 數據結構     |  NULL |
| 96001 | 劉軍   | 數據處理     |  NULL |
| 96001 | 劉軍   | C語言        |    86 |
+-------+--------+--------------+-------+

 

排序:

select [ ] from <表名> order by <列名> [desc/asc];

mysql> select sno,sname from student order by sno; //預設為升序
+-------+--------+
| sno   | sname  |
+-------+--------+
| 12001 | bgg    |
| 94001 | 山寨   |
| 95001 | 李勇   |
| 95002 | 劉晨   |
| 95003 | 王敏   |
| 95004 | 張立   |
| 95005 | 張三   |
| 96001 | 劉軍   |
| 96004 | 芙蓉   |
| 97001 | 李四   |
+-------+--------+

mysql> select sno,sname from student order by sno asc; //asc 修飾為升序
+-------+--------+
| sno   | sname  |
+-------+--------+
| 12001 | bgg    |
| 94001 | 山寨   |
| 95001 | 李勇   |
| 95002 | 劉晨   |
| 95003 | 王敏   |
| 95004 | 張立   |
| 95005 | 張三   |
| 96001 | 劉軍   |
| 96004 | 芙蓉   |
| 97001 | 李四   |
+-------+--------+
10 rows in set (0.05 sec)

mysql> select sno,sname from student order by sno desc; //desc 修飾為降序
+-------+--------+
| sno   | sname  |
+-------+--------+
| 97001 | 李四   |
| 96004 | 芙蓉   |
| 96001 | 劉軍   |
| 95005 | 張三   |
| 95004 | 張立   |
| 95003 | 王敏   |
| 95002 | 劉晨   |
| 95001 | 李勇   |
| 94001 | 山寨   |
| 12001 | bgg    |
+-------+--------+

mysql> select sno,sname from student order by sno desc,sname asc; //先按sno降序 再按sname升序
+-------+--------+
| sno   | sname  |
+-------+--------+
| 97001 | 李四    |
| 96004 | 芙蓉    |
| 96001 | 劉軍    |
| 95005 | 張三    |
| 95004 | 張立    |
| 95003 | 王敏    |
| 95002 | 劉晨    |
| 95001 | 李勇    |
| 94001 | 山寨    |
| 12001 | bgg    |
+-------+--------+
10 rows in set (0.05 sec)

 

選擇的between操作(在mysql/mariadb中是閉區間):

select * from <表名>  where <列名> between 'a' and 'b';

mysql> select * from student where sno between '94001' and '96001';
+-------+--------+------+------+-------+
| sno   | sname  | ssex | sage | sdept |
+-------+--------+------+------+-------+
| 94001 | 山寨   | 男   |   29 | CS    |
| 95001 | 李勇   | 男   |   20 | CS    |
| 95002 | 劉晨   | 女   |   19 | IS    |
| 95003 | 王敏   | 女   |   19 | MA    |
| 95004 | 張立   | 男   |   20 | IS    |
| 95005 | 張三   | 男   |   23 | CS    |
| 96001 | 劉軍   | 男   |   30 | IS    |
+-------+--------+------+------+-------+

//not between and

mysql> select * from student where sno not between '94001' and '96001';
+-------+--------+------+------+-------+
| sno   | sname  | ssex | sage | sdept |
+-------+--------+------+------+-------+
| 12001 | bgg    | M    | 26   | CS    |
| 96004 | 芙蓉    | 女   | 32   | CH    |
| 97001 | 李四    | 男   | 26   | EN    |
+-------+--------+------+------+-------+

mysql模糊查詢(LIKE)關鍵字:

% 替代一個或多個字元;

_ 僅替代一個字元;

[charlist] 字元列中的任何單一字元;

[!charlist] 或 [^charlist] 不在字元列中的任何單一字元; 

//查詢sno以95開頭的學生信息
mysql> select * from student where sno like '95%';
+-------+--------+------+------+-------+
| sno   | sname  | ssex | sage | sdept |
+-------+--------+------+------+-------+
| 95001 | 李勇   | 男   |   20 | CS    |
| 95002 | 劉晨   | 女   |   19 | IS    |
| 95003 | 王敏   | 女   |   19 | MA    |
| 95004 | 張立   | 男   |   20 | IS    |
| 95005 | 張三   | 男   |   23 | CS    |
+-------+--------+------+------+-------+
5 rows in set (0.05 sec)

//查詢sno以01結尾的學生信息
mysql> select * from student where sno like '%01';
+-------+--------+------+------+-------+
| sno   | sname  | ssex | sage | sdept |
+-------+--------+------+------+-------+
| 12001 | bgg    | M    |   26 | CS    |
| 94001 | 山寨   | 男   |   29 | CS    |
| 95001 | 李勇   | 男   |   20 | CS    |
| 96001 | 劉軍   | 男   |   30 | IS    |
| 97001 | 李四   | 男   |   26 | EN    |
+-------+--------+------+------+-------+
5 rows in set (0.05 sec)
//查詢sno以01結尾的學生信息
//not like

mysql> select * from student where sno not like '%01';
+-------+--------+------+------+-------+
| sno   | sname  | ssex | sage | sdept |
+-------+--------+------+------+-------+
| 95002 | 劉晨    | 女   | 19   | IS    |
| 95003 | 王敏    | 女   | 19   | MA    |
| 95004 | 張立    | 男   | 20   | IS    |
| 95005 | 張三    | 男   | 23   | CS    |
| 96004 | 芙蓉    | 女   | 32   | CH    |
+-------+--------+------+------+-------+

IN操作符:

 IN操作符允許在WHERE子句中規定多個值;

// 查詢 sdept為MA,CS的信息
mysql> select * from student where sdept in ('MA','CS');
+-------+--------+------+------+-------+
| sno   | sname  | ssex | sage | sdept |
+-------+--------+------+------+-------+
| 12001 | bgg    | M    |   26 | CS    |
| 94001 | 山寨   | 男   |   29 | CS    |
| 95001 | 李勇   | 男   |   20 | CS    |
| 95003 | 王敏   | 女   |   19 | MA    |
| 95005 | 張三   | 男   |   23 | CS    |
+-------+--------+------+------+-------+

 

2018-05-01  20:24:33


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1. 表達式 表達式必須跟在“@”符號之後, 2. 代碼塊 代碼塊必須位於“@{}”中,並且每行代碼必須以“;”結尾。代碼塊中定義的變數可能會被同一個域中的其他塊使用。比如,定義在視圖頂部的變數可以被同一視圖中的代碼塊和代碼段訪問。 3. 佈局 Razor通過layouts保持網頁外觀佈局的一致性。 ...
  • 問題描述:在使用VS2015調試WCF時,偶遇拋出異常名稱不能以“<”字元(十六進位0x3c)開頭,平時運行時(不調試)沒有問題的。 解決方法:檢查後發現為了檢查異常的位置,勾選了引發通用語言運行時的設置,取消勾選設置就可以了。 ...
  • 首先在https://hub.docker.com查找core官方鏡像,相關參數設置https://hub.docker.com/r/microsoft/dotnet/有詳細說明 Dockerfile文件內容: ...
  • 1、在Login.aspx頁面Load中加入 if (!IsPostBack && Request.UrlReferrer != null) { Session[ "url"] = Request.UrlReferrer; } 2、在登錄按鈕事件中加入 if (Session["url"] != n ...
  • 待更新 ...
  • 1. 概況 1.1 任務 口語理解(Spoken Language Understanding, SLU) 作為語音識別與自然語言處理之間的一個新興領域,其目的是為了讓電腦從用戶的講話中理解他們的意圖。SLU是口語對話系統( "Spoken Dialog Systems" )的一個非常關鍵的環節。 ...
  • Alias——使用一個列名別名AS 關鍵字: GROUP BY語句: 比如在合計(sum函數)的時候常需要用group by語句來進行分類求和 2018-05-01 23:21:52 ...
  • 原文鏈接:http://www.cnblogs.com/xrq730/p/8944539.html,轉載請註明出處,謝謝 本文目錄 上一篇文章以認識Redis為主,寫了Redis系列的第一篇,現在開啟第二部分的學習,在本文中,我們將看到以下內容: Redis數據結構String、Hash、List、 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...