亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL數(shù)據(jù)庫CRUD、常見函數(shù)及union查詢詳解

 更新時間:2024年01月05日 10:21:08   作者:星辰.606  
在MySQL中CRUD是指對數(shù)據(jù)庫進行增加(Create)、讀取(Retrieve)、更新(Update)和刪除(Delete)這四種基本操作的縮寫,這篇文章主要給大家介紹了關(guān)于MySQL數(shù)據(jù)庫CRUD、常見函數(shù)及union查詢的相關(guān)資料,需要的朋友可以參考下

一.CRUD

1.1 SELECT(查詢)

1.概念:

  • 查詢數(shù)據(jù)是指從數(shù)據(jù)庫中根據(jù)需求,使用不同的查詢方式來獲取不同的數(shù)據(jù),是使用頻率最高、最重要的操作。

2.語法:

SELECT
{*|<字段名>}
[FROM<表1>,<表2>...
[WHERE<表達式>
[GROUP BY <group by definition>
[HAVING<expression>[{<operator><expression>}...]]
[ORDER BY <order by definition>]
[LIMIT[<offset>,]<row count>]
]

3.含義:

  • '{*|<字段列名>}'包含信星號通配符的字段列表,表示所要擦汗尋字段名稱。
  • '<表1>,<表2>'...,表1和表2表示查詢數(shù)據(jù)的來源,可以是單個或多個。
  • 'WHERE<表達式>'是可選項,如果選擇該項,將限定查詢數(shù)據(jù)必須滿足該查詢條件。
  • 'GROUP BY<字段>',該子句告訴MySQL如何顯示查詢出來的數(shù)據(jù),并按照指定的字段分組。
  • '[ORDER BY <字段>]',該子句告訴MySQL按什么樣的順序顯示查詢出來的數(shù)據(jù),可以進行的排序有升序(ASC)和降序(DESC),默認情況下是升序。
  • '[LIMIT[<offset>,]<row count>]',該子句告訴MySQL每次顯示查詢出來的數(shù)據(jù)條數(shù)。

1.2 INSERT(新增)

1.概念:

  • 使用INSERT語句向數(shù)據(jù)庫已有的表中插入一行或者多行元組數(shù)據(jù)。

2.語法:

  • INSERT...VALUES語句:INSERT INTO <表名> [<列名1>[,...<列名n>]] VALUES (值1)[...,(值n)];
  • INSERT...SET語句:INSERT INTO <表名> SET <列名> = <值1>,<列名> = <值2>, ....

3.含義:

  • <表名>:指定被操作的表名。
  • <列名>:指定需要插入數(shù)據(jù)的列名。若向表中的所有列插入數(shù)據(jù),則全部的列名均可以省略,直接采用 INSERT<表名>VALUES(...)即可。
  • VALUES 或 VALUE 子句:該子句包含要插入的數(shù)據(jù)清單。數(shù)據(jù)清單中數(shù)據(jù)的順序要和列的順序相對應(yīng)。

1.3 UPDATE(修改)

1.語法:

  • UPDATE<表名> SET 字段1 = 值1 [,字段2 = 值2...][WHERE 子句]
    [ORDER BY 子句][LIMT 子句]

2.含義:

  • <表名>:用于指定要更新的表名稱
  • SET子句:用于指定表中要修改的列名及其列值。其中,每個指定的列值可以是表達式,也可以是該列對應(yīng)的默認值。如果指定的是默認值,可用關(guān)鍵字DEFAULT 表示列值。
  • WHERE子句:可選項。用于限定表中要修改的行。若不指定,則修改表中所有的行。
  • ORDER BY 子句:可選項。用于限定表中的行被修改的次序。
  • LIMIT子句:可選項。用于限定被修改的行數(shù)。

1.4 DELETE(刪除)

1.語法:

  • DELETE FORM <表名> [WHERE 子句] [ORDER BY子句] [LIMIT 子句]

2.含義:

  • <表名>:指定要刪除數(shù)據(jù)的表名。
  • ORDER BY 子句:可選項。表示刪除時,表中各行將按照子句中指定的順序進行刪除。
  • WHERE 子句:可選項。表示為刪除操作限定刪除條件,若省略該子句,則代表刪除該表中的所有行。
  • LIMIT 子句:可選項。用于告知服務(wù)器在控制命令被返回到客戶端前被刪除行的最大值。

二.函數(shù)

2.1 常見函數(shù)

1.字符函數(shù):

  • 轉(zhuǎn)小寫——LOWER('SQL Course')——sql course
  • 轉(zhuǎn)大寫——UPPER('SQL Course')——SQL COURSE
  • 拼接——CONCAT('Hello','World')——HelloWorld
  • 截取——SUBSTR('HelloWorld',1,5)——Hello
  • 長度——LENGTH('HelloWorld')——10
  • 字符出現(xiàn)索引值——INSTR('HelloWorld','W')——6
  • 字符截取后半段——TRIM('H' FROM 'HelloWorld')——elloWorld
  • 字符替換——REPLACE('abcd','b','m')——amcd

2.數(shù)字函數(shù):

  • 四舍五入——ROUND(45.926,2)——45.93
  • 截斷——TRUNC(45.926,2)——45.92
  • 求余——MOD(1600,300)——100

3.日期函數(shù):

  • 獲取當(dāng)前日期——now()
  • 將日期格式的字符轉(zhuǎn)換成指定格式的日期——STR_TO_DATE('9_13_1999','%m-%d-%Y')——1999-09-13
  • 將日期轉(zhuǎn)換成字符串——DATE_FORMAT('2018/6/6','%Y年%m月%d日')——2018年06月06日

2.2 流程控制函數(shù)

1.使用場景:

  • 行轉(zhuǎn)列:把基本不需要改動的數(shù)據(jù)放在行,把可能要進行變化的數(shù)據(jù)放在列

2.語法:

  • CASE expr WHEN comparison_expr1 THEN return_expr1
    [WHEN comparison_expr2 THEN return_expr2
    WHEN comparison_exprn THEN return_exprn
    ELSE else_expr]
    END

3.示例:

  • 01)查詢同時存在" 01 "課程和" 02 "課程的情況:
SELECT
t3.*,
(CASE WHEN t1.cid = '01' THEN t1.score END) 語文,
(CASE WHEN t2.cid = '02' THEN t2.score END) 數(shù)學(xué)
FROM
( SELECT * FROM t_mysql_score sc WHERE sc.cid = '01') t1,
( SELECT * FROM t_mysql_score sc WHERE sc.cid = '02') t2,
t_mysql_student t3
WHERE
t1.sid = t2.sid
AND t1.sid = t3.sid
  • 02)查詢會議信息(包含會議信息表數(shù)據(jù),主持人姓名、審批人姓名、會議狀態(tài)):
SELECT a.id,a.title,a.content,a.canyuze,a.liexize,a.zhuchiren,b.`name`,a.location
     ,DATE_FORMAT(a.startTime,'%Y-%m-%d %H:%i:%s') as startTime
     ,DATE_FORMAT(a.endTime,'%Y-%m-%d %H:%i:%s') as endTime
     ,a.state
     ,(case a.state
     when 0 then '取消會議'
     when 1 then '新建'
     when 2 then '待審核'
     when 3 then '駁回'
     when 4 then '待開'
     when 5 then '進行中'
     when 6 then '開啟投票'
     else '結(jié)束會議' end
     ) as meetingState
     ,a.seatPic,a.remark,a.auditor,c.`name` as auditorName
     FROM t_oa_meeting_info a
     inner join t_oa_user b on a.zhuchiren = b.id
     left JOIN t_oa_user c on a.auditor = c.id where 1 = 1 ;

2.3 聚合函數(shù)

  • sum 求和
  • avg 平均值
  • max 最大值
  • min 最小值
  • count 計算個數(shù)

三.union與union all

3.1 概念

  • union:用于合并兩個或者多個SELECT語句的結(jié)果集,并去除重復(fù)的行。
  • union all:用于合并兩個或者多個SELECT語句的結(jié)果集,包括重復(fù)的行。

3.2 語法

  • union: 
    將多個SELECT語句放在一起,并使用UNION關(guān)鍵字將它們連接起來。每個SELECT語句的列數(shù)、列名和數(shù)據(jù)類型必須相同。
  • union all:
    將多個SELECT語句放在一起,并使用UNION ALL關(guān)鍵字將它們連接起來。每個SELECT語句的列數(shù)、列名和數(shù)據(jù)類型可以不同。

3.3 專業(yè)詞解釋

  • union:UNION操作符執(zhí)行去除重復(fù)行的操作,它通過對所有的結(jié)果集進行排序和比較來實現(xiàn)
  • union all:UNION ALL操作符不執(zhí)行去除重復(fù)行的操作,它直接將所有的結(jié)果集合并在一起。

3.4 使用場景

  • union:
    當(dāng)需要合并多個查詢結(jié)果,并且不希望出現(xiàn)重復(fù)行時,可以使用UNION操作符。它適用于數(shù)據(jù)需要去重的情況。
  • union all:
    當(dāng)需要合并多個查詢結(jié)果,包括重復(fù)行時,可以使用UNION ALL操作符。它適用于不需要去重的情況,或者在已經(jīng)確定結(jié)果不會有重復(fù)行的情況下。

3.5 實例

3.5.1 全列

1.初始數(shù)據(jù):

  • SELECT * from t_oa_meeting_info where id>=1 and id <= 8;

    SELECT * from t_oa_meeting_info where id>=6 and id <= 10;

2.UNION:

  • SELECT * from t_oa_meeting_info where id>=1 and id <= 8;

    UNION

    SELECT * from t_oa_meeting_info where id>=6 and id <= 10;
    678只出現(xiàn)了1次

3.UNION all:

  • SELECT * from t_oa_meeting_info where id>=1 and id <= 8;

    UNION ALL

    SELECT * from t_oa_meeting_info where id>=6 and id <= 10;
    678重復(fù)出現(xiàn) 

單列與全列用法相同

3.5.2 結(jié)論

相當(dāng)于數(shù)學(xué)中的交集和并集,所謂去重并不需要所有列相同。

四.思維導(dǎo)圖

總結(jié) 

到此這篇關(guān)于MySQL數(shù)據(jù)庫CRUD、常見函數(shù)及union查詢的文章就介紹到這了,更多相關(guān)MySQL CRUD、函數(shù)及union查詢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 關(guān)于MySQL數(shù)據(jù)庫死鎖的案例和解決方案

    關(guān)于MySQL數(shù)據(jù)庫死鎖的案例和解決方案

    MySQL Update語句防止死鎖是指在修改MySQL數(shù)據(jù)庫的數(shù)據(jù)時,為避免多個進程同時修改同一數(shù)據(jù)行而造成死鎖的情況,引入了一些機制來防止死鎖的產(chǎn)生,本文介紹了一個 MySQL 數(shù)據(jù)庫死鎖的案例和解決方案,需要的朋友可以參考下
    2023-09-09
  • 基于unique與primary約束的區(qū)別分析

    基于unique與primary約束的區(qū)別分析

    本篇文章介紹了unique與primary約束的區(qū)別分析。需要的朋友參考下
    2013-04-04
  • 淺談mysql的sql_mode可能會限制你的查詢

    淺談mysql的sql_mode可能會限制你的查詢

    本文主要介紹了淺談mysql的sql_mode可能會限制你的查詢,這個問題主要說明的是,我們寫的sql查詢語句違背了聚合函數(shù)group?by的規(guī)則,下面就來介紹一下解決方法,感興趣的可以了解一下
    2025-03-03
  • MySQL使用GROUP?BY使用技巧和注意事項總結(jié)

    MySQL使用GROUP?BY使用技巧和注意事項總結(jié)

    GROUP?BY?子句是?在MySQL?中用于將查詢結(jié)果按照指定的列或表達式進行分組的關(guān)鍵字,它通常與聚合函數(shù)一起使用,能夠?qū)γ總€分組進行統(tǒng)計或計算,本文給大家總結(jié)了MySQL使用GROUP?BY使用技巧和注意事項,需要的朋友可以參考下
    2024-05-05
  • mysql下完整導(dǎo)出導(dǎo)入實現(xiàn)方法

    mysql下完整導(dǎo)出導(dǎo)入實現(xiàn)方法

    對于大量數(shù)據(jù)的導(dǎo)入導(dǎo)出,是件挺麻煩的事,需要考慮很多的細節(jié),這類對于需要大量數(shù)據(jù)導(dǎo)入導(dǎo)出的朋友可以參考下。
    2010-12-12
  • mysql存儲過程實例

    mysql存儲過程實例

    這篇文章主要介紹了mysql存儲過程實例,需要的朋友可以參考下
    2014-04-04
  • MySQL主從庫過濾復(fù)制配置教程

    MySQL主從庫過濾復(fù)制配置教程

    搭建MySQL主從庫過濾復(fù)制,備份指定數(shù)據(jù)庫,有利于數(shù)據(jù)庫的管理,本文主要介紹了MySQL主從庫過濾復(fù)制配置教程,具有一定的參考價值,感興趣的可以了解一下
    2024-03-03
  • MySQL刪除表數(shù)據(jù)、清空表命令詳解(truncate、drop、delete區(qū)別)

    MySQL刪除表數(shù)據(jù)、清空表命令詳解(truncate、drop、delete區(qū)別)

    介紹了MySQL中清空或刪除表數(shù)據(jù)的三種方法:truncate、delete和drop,以及它們的特點、使用場景和注意事項,Truncate用于快速刪除表中所有數(shù)據(jù)并釋放空間,但不保留表結(jié)構(gòu);delete用于刪除表中特定行或所有數(shù)據(jù),保留表結(jié)構(gòu)且操作可回滾
    2024-10-10
  • Linux服務(wù)器中MySQL遠程連接的開啟方法

    Linux服務(wù)器中MySQL遠程連接的開啟方法

    今天在Linux服務(wù)器上安裝了msyql數(shù)據(jù)庫,在本地訪問的時候可以訪問,但是我想通過遠程的方式訪問的時候就不能訪問了,查詢資料后發(fā)現(xiàn),Linux下MySQL默認安裝完成后只有本地訪問的權(quán)限,沒有遠程訪問的權(quán)限,需要你給指定用戶設(shè)置訪問權(quán)限才能遠程訪問該數(shù)據(jù)庫
    2017-06-06
  • MySQL使用物理方式快速恢復(fù)單表

    MySQL使用物理方式快速恢復(fù)單表

    這篇文章主要介紹了MySQL使用物理方式快速恢復(fù)單表,本文通過示例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-12-12

最新評論