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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...