MySQL語句整理(二)

来源:https://www.cnblogs.com/qingchang/archive/2018/05/26/9091190.html
-Advertisement-
Play Games

資料庫操作前的準備 -- 創建資料庫 -- create database python_test_1 charset=utf8; -- 使用資料庫 -- use python_test_1; -- students表 -- create table students( -- id int unsi ...


資料庫操作前的準備
-- 創建資料庫
-- create database python_test_1 charset=utf8;
 
-- 使用資料庫
-- use python_test_1;
 
-- students表
-- create table students(
--     id int unsigned primary key auto_increment not null,
--     name varchar(20) default '',
--     age tinyint unsigned default 0,
--     height decimal(5,2),
--     gender enum('男','女','中性','保密') default '保密',
--     cls_id int unsigned default 0,
--     is_delete bit default 0
-- );
-- classes表 -- create table classes ( --     id int unsigned auto_increment primary key not null, --     name varchar(30) not null -- );    -- 查詢     -- 查詢所有欄位     -- select * from 表名;     select * from students;       -- 查詢指定欄位     -- select 列1,列2,... from 表名;     select name,age from  students;       -- 使用 as 給欄位起別名     -- select 欄位 as 名字.... from 表名;     select name as "姓名" , age from students;     -- select 表名.欄位 .... from 表名;     select students.name,students.age from students;          -- 可以通過 as 給表起別名     -- select 別名.欄位 .... from 表名 as 別名;     select s.name ,s.age from  students as s;       -- 消除重覆行(查性別)     -- distinct 欄位     select distinct gender from students;   -- 條件查詢     -- 比較運算符         -- select .... from 表名 where .....         -- >         -- 查詢年紀大於18歲的信息         select * from students where age > 18;           -- <         -- 查詢年紀小於18歲的信息         select * from students where age < 18;           -- >=,<=         -- 查詢小於或者等於18歲的信息         selec * tfrom students where age <= 18;         -- =         -- 查詢年齡為18歲的所有學生的名字         select * from students where age = 18;           -- != 或者 <>         -- 查詢年齡不為18歲的所有學生的名字         -- select * from students where age != 18;         -- select * from students where age <> 18;             -- 邏輯運算符         -- and         -- 18和28之間的所以學生信息         select * from students where age > 18 and age < 28;         -- 18歲以上的女性         select * from students where age > 18 and gender = "女";           -- or         -- 18以上或者身高高過180(包含)以上         select * from students where age > 18 or height >= 180;                  -- not         -- 不在 18歲以上的女性 這個範圍內的信息         -- select * from students where not (age>18 and gender=2);             select * from students where not (age > 18 and gender = "女");             select * from students where not age > 18 and gender = "女";       -- 模糊查詢(where name like 要查詢的數據)         -- like         -- % 替換任意個         -- _ 替換1個         -- 查詢姓名中 以 "小" 開始的名字         select * from students where name like '小%';         -- 查詢姓名中 有 "小" 所有的名字         select * from students where name like "%小%";         -- 查詢有2個字的名字         select * from students where name like '__';         -- 查詢有3個字的名字         select * from students where name like "___";         -- 查詢至少有2個字的名字         select * from students where name like "__%";              -- 範圍查詢         -- in (1, 3, 8)表示在一個非連續的範圍內         -- 查詢 年齡為18或34的姓名         select * from  students where age in (18,34);               -- not in 不非連續的範圍之內         -- 年齡不是 18或34歲的信息         select * from students where age not in (18,34);                  -- between ... and ...表示在一個連續的範圍內         -- 查詢 年齡在18到34之間的的信息         select * from students where age between 18 and 34;         -- not between ... and ...表示不在一個連續的範圍內         -- 查詢 年齡不在18到34之間的的信息             select * from students where age not between 18 and 34;       -- 空判斷         -- 判空is null         -- 查詢身高為空的信息         select * from students where height is null;           -- 判非空is not null         select * from students where height is not null;   -- 排序     -- order by 欄位     -- asc     -- asc從小到大排列,即升序     -- desc     -- desc從大到小排序,即降序     -- 查詢年齡在18到34歲之間的男性,按照年齡從小到大到排序     -- order by  asc  desc     select * from students where age between 18 and 34 order by age asc;     -- 查詢年齡在18到34歲之間的女性,身高從高到矮排序     select * from students where age between 18 and 34 and gender = "女" order by height desc;       -- order by 多個欄位     -- 查詢年齡在18到34歲之間的女性,身高從高到矮排序, 如果身高相同的情況下按照年齡從小到大排序     select * from students where age between 18 and 34 and gender = "女" order by height desc,age asc  ;     -- 如果年齡也相同那麼按照id從大到小排序     select * from students where age between 18 and 34 and gender = "女" order by height desc,age asc,id desc  ;   -- 聚合函數 分組函數     -- 總數     -- count()     -- 查詢男性有多少人     select count(*) from students where gender = "男";          -- 最大值     -- max()     -- 查詢最大的年齡     select max(age) from students ;     -- 查詢女性的最高 身高     select max(height) from students where gender = "女";          -- 最小值     -- min()     select min(age) from students;          -- 求和     -- sum()     -- 計算所有人的年齡總和     select sum(age) from students;         -- 平均值     -- avg()     -- 計算平均年齡     select avg(age) from students;     -- 計算平均年齡 sum(age)/count(*)     select sum(age)/count(*) from students;          -- 四捨五入 round(123.23 , 1) 保留1位小數     -- 計算所有人的平均年齡,保留2位小數     select round( avg(age),2) from students;     -- 計算男性的平均身高 保留2位小數     select round(avg(height), 2) from students where gender = "男";   -- 分組     -- group by     -- 按照性別分組,查詢所有的性別     select gender from students group by gender;     #以誰分組就在select中寫什麼欄位     -- select 分組欄位 from 表名 group by 分組欄位;     -- 計算每種性別中的人數     select gender,count(*) from students group by gender;       -- group_concat(...)     -- 查詢同種性別中的姓名     select gender,group_concat(name) from students group by gender;     -- 查詢每組性別的平均年齡     select gender,avg(age) from students group by gender;          -- having(註意having和group by 連用 having後通常也要跟 聚合函數)     -- 查詢平均年齡超過30歲的性別,以及姓名     select avg(age) from students;     select gender from students group by gender having avg(age) > 30;     -- 查詢每種性別中的人數多於2個的信息     select gender from students group by gender having count(*) > 2;       -- with rollup 彙總的作用(瞭解)     select gender,count(*) from students group by gender with rollup;   -- 分頁     -- limit start, count     -- limit 放在最後面(註意)     起始頁計算:(頁數位置-1) * 每頁的個數     -- 限制查詢出來的數據個數     -- 查詢前5個數據     select * from students limit 0,5;     -- 每頁顯示2個,顯示第6頁的信息, 按照年齡從小到大排序     select * from students order by age asc limit 10,2;   -- 連接查詢     -- inner join ... on     -- select ... from 表A inner join 表B;     -- 查詢 有能夠對應班級的學生以及班級信息     select * from students inner join classes on students.cls_id = classes.id;     -- 按照要求顯示姓名、班級     select students.name,classes.name from students inner join classes on students.cls_id = classes.id;     -- 給數據表起名字     select * from students as s inner join classes as c on s.cls_id = c.id;     -- 查詢 有能夠對應班級的學生以及班級信息,顯示學生的所有信息 students.*,只顯示班級名稱 classes.name.     select students.*,classes.name from students inner join classes on students.cls_id = classes.id;     -- 在以上的查詢中,將班級名顯示在第1列     select classes.name , students.*from students inner join classes on students.cls_id = classes.id;     -- 查詢 有能夠對應班級的學生以及班級信息, 按照班級名進行排序      select classes.name , students.*from students inner join classes on students.cls_id = classes.id order by classes.name;     -- 當時同一個班級的時候,按照學生的id進行從小到大排序     select classes.name , students.*from students inner join classes on students.cls_id = classes.id order by classes.name asc,students.id asc;       -- left join    on     -- 查詢每位學生對應的班級信息     select * from students left join classes on students.cls_id = classes.id;     -- 查詢沒有對應班級信息的學生     select * from students left join classes on students.cls_id = classes.id where classes.name is null;          -- right join   on     -- 將數據表名字互換位置,用left join完成     select * from students right join classes on students.cls_id = classes.id;   -- 子查詢     -- 標量子查詢: 子查詢返回的結果是一個數據(一行一列)     -- 列子查詢: 返回的結果是一列(一列多行)     -- 行子查詢: 返回的結果是一行(一行多列)          -- 查詢出高於平均身高的信息(height)     select avg(height) from students;     select * from students where height > (select avg(height) from students);     -- 查詢學生的班級號能夠對應的 學生名字     select id from classes;     select * from students where cls_id in( select id from classes );
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • awk:把文件逐行的讀入,以空格為預設分隔符將每行切片,切開的部分再進行各種分析處理,是一個強大的文本分析工具,在對數據分析並生成報告時很有優勢。 awk有3個不同版本: awk、nawk和gawk,未作特別說明,一般指gawk,gawk 是 AWK 的 GNU 版本。 命令格式: 變數 常見內置變 ...
  • 一 進程空間分佈概述 對於一個進程,其空間分佈如下圖所示: 程式段(Text):程式代碼在記憶體中的映射,存放函數體的二進位代碼。 初始化過的數據(Data):在程式運行初已經對變數進行初始化的數據。 未初始化過的數據(BSS):在程式運行初未對變數進行初始化的數據。 棧 (Stack):存儲局部、臨 ...
  • 一、實驗拓撲圖: 二、實驗目標:部署標準交換機和分散式交換機 三、實驗步驟: 標準交換機的配置 1、分別在兩台esxi主機中添加6塊物理網卡,橋接到vmnet1。 通過宿主機連接到sql-vcenter 2、分別在兩台esxi主機配置標準交換機,將vSwitch0交換機添加一個物理網卡,實現負載均衡 ...
  • Mac編譯安裝swfToolsMac編譯安裝swfTools下載源碼解壓源碼安裝依賴項./configure執行配置或者執行如下配置命令:需要註意這裡存在部分代碼錯誤,需要修改解決後執行一、char * 和 int比較導致的錯誤, 需要修為文件二、存在一些變數沒有定義的錯誤三、存在一些方法參數數量錯... ...
  • 前面給大家介紹了很多在Linux安裝軟體的知識,這些軟體往往依賴了很多第三方的工具或者軟體,如果在Linux伺服器有外網的情況,咱們可以通過yum install這樣的命令直接去安裝這些相關的工具或者軟體,比如: 但是我們在平時的項目開發和運維當中,伺服器為了安全是不一定會開放外網的,對於部署在內網 ...
  • 我們知道用linux命令rz/sz可以通過一些終端軟體如secureCRT等在linux伺服器與本地windows之間傳文件。在伺服器上rz一下,在本地windows下就跳出一個視窗,選擇文件後就傳到了伺服器上;而在伺服器上用sz命令sz一個文件,在本地電腦硬碟上就有了這個文件。用起來是很方便,但是 ...
  • ##/proc的意義在linux查看各種狀態,其實質是查看內核中相關進程的數據結構中的項通過工具將其格式化後輸出出來。但是內核的數據是絕對不能隨意查看或更改的,至少不能直接去修改。所以,在linux上出現了偽文件系統/proc,它是內核中各屬性或狀態向外提供訪問和修改的介面。##查看進程信息 pst ...
  • 今天淺談一下三大操作系統(Operation System): Windows , MacOS , Linux。 適合碼農使用的操作系統是:MacOS 和 Linux。 簡答做了一個思維導圖如下(僅供參考) 1.操作系統的作用 通過提供系統調用,控制和管理硬體。(應用軟體 --> 操作系統 系統調用 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...