欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL跨表查詢與跨表更新

 更新時間:2020年02月04日 09:39:20   作者:日拱一兵  
本文主要給大家講解的是MySQL中如何使用跨表更新的方法和示例,非常的實(shí)用,有需要的小伙伴可以查看查看

有點(diǎn) SQL 基礎(chǔ)的朋友肯定聽過 「跨表查詢」,那啥是跨表更新啊?

背景

項(xiàng)目新導(dǎo)入了一批人員數(shù)據(jù),這些人的有的部門名稱發(fā)生了變化,有的聯(lián)系方式發(fā)生了變化,暫且稱該表為

t_dept_members, 系統(tǒng)中有另外一張表 t_user_info 記錄了人員信息。要求將 t_dept_members 中有變化的信息更新到 t_user 表中,這個需求就是「跨表更新」啦

憨B SQL 直接被秒殺

不帶腦子出門的就寫出了下面的 SQL

看到身后 DBA 小段總在修仙,想著讓他幫潤色一下😜,于是發(fā)給了他,然后甩手回來就是這個樣子:

看到這個 SQL 語句我都驚呆了,還能這樣寫,在無情的嘲笑下,一聲 KO 我直接倒下。死也得死的明白,咱得查查這是咋回事啊

Mysql Update Join

我們經(jīng)常使用 join 查詢表中具有(在 INNER JOIN 情況下)或可能沒有(在 LEFT JOIN 情況下)另一個表中匹配行的表中的行。

同樣,在 MySQL 中, 我們也可以在 UPDATE 語句中使用 JOIN 子句執(zhí)行跨表更新,語法就是這樣:

UPDATE T1, T2,
[INNER JOIN | LEFT JOIN] T1 ON T1.C1 = T2. C1
SET T1.C2 = T2.C2,
  T2.C3 = expr
WHERE condition

我們還是詳細(xì)的說明一下上面的語法:

首先,在 UPDATE 子句之后,指定主表(T1)和希望主表聯(lián)接到的表(T2)。請注意,必須在UPDATE 子句之后至少指定一個表接下來,指定你要使用的聯(lián)接類型,即 INNER JOIN 或 LEFT JOIN 以及聯(lián)接謂詞。 JOIN子句必須出現(xiàn)在 UPDATE 子句之后(這個大家都是知道的哈)然后,將新值分配給要更新的 T1或 T2 表中的列最后,在 WHERE 子句中指定一個條件以將行限制為要更新的行

如果你遵循 update 語法,你會發(fā)現(xiàn)有另外一種語法也可以完成跨表更新

UPDATE T1, T2
SET T1.c2 = T2.c2,
   T2.c3 = expr
WHERE T1.c1 = T2.c1 AND condition

上面的語法其實(shí)隱式使用了 inner join 關(guān)鍵字,完全等同于下面的樣子:

UPDATE T1,T2
INNER JOIN T2 ON T1.C1 = T2.C1
SET T1.C2 = T2.C2,
   T2.C3 = expr
WHERE condition

個人建議還是加上 inner join 關(guān)鍵字吧,這樣可讀性更好,盡享絲滑,你覺得呢?

我摸魚看到的,覺得是靈魂翻譯

談太廉,秀你碼 (Talk is cheap,show me the code)

Update Join 例子

年底了,又到了評績效的時候了,就是那個叫 KPI 的東東(你們有嗎),聽說要根據(jù) KPI 調(diào)工資了。有兩張表

第一張表「employees-員工表」

建表語句如下:

create table employees
(
  employee_id bigint auto_increment comment '員工ID,主鍵',
  employee_name varchar(50) null comment '員工名稱',
  performance int(4) null comment '績效分?jǐn)?shù) 1,2,3,4,5',
  salary float null comment '員工薪水',
  constraint employees_pk
    primary key (employee_id)
)
comment '員工表';

第二張表「merits-績效字典表」

建表語句如下:

create table merits
(
  performance int(4) null,
  percentage float null
)
comment '績效字典表';

先生成一些模擬數(shù)據(jù)

-- 績效字典初始化數(shù)據(jù)
INSERT INTO merits(performance, percentage)
VALUES (1, 0),
    (2, 0.01),
    (3, 0.03),
    (4, 0.05),
    (5, 0.08);


-- 員工表初始化數(shù)據(jù)
INSERT INTO employees(employee_name, performance, salary)
VALUES ('拱哥', 1, 1000),
    ('小段總', 3, 20000),
    ('大人', 4, 18000),
    ('司令', 5, 28000),
    ('老六', 2, 10000),
    ('羅蒙', 3, 20000);

調(diào)薪規(guī)則:

原有薪資 + (原有薪資 * 當(dāng)前績效對應(yīng)的調(diào)薪百分比)

按照調(diào)薪規(guī)則寫 update 語句:

UPDATE employees
  INNER JOIN
  merits ON employees.performance = merits.performance
SET salary = salary + salary * percentage;

拱哥績效不好,沒給漲工資......

三橫一豎一咕嘎,四個小豬🐷來吃zha,咕嘎咕嘎又來倆

臨近年底,公司又來了兩位新同事, 但是公司年度績效已經(jīng)評完,所以新員工績效為 NULL

INSERT INTO employees(employee_name, performance, salary)
VALUES ('馮大', NULL, 8000),
    ('馮二', NULL, 5000);

新員工工作干的不錯,也要 1.5% 漲點(diǎn)工資的。如果我們還是用 UPDATE INNER JOIN,按照上面的更新語句是不可能完成的,因?yàn)闂l件等式不成立,這是我們就要用到 UPDATE LEFT JOIN

UPDATE employees
  LEFT JOIN
  merits ON employees.performance = merits.performance
SET salary = salary + salary * 0.015
WHERE merits.percentage IS NULL;

到這里,新員工的漲薪工作也做完,拱哥由于知識點(diǎn)了解不透徹,灰溜溜的回家過年

相關(guān)文章

  • MySql數(shù)據(jù)庫時間序列間隔查詢方式

    MySql數(shù)據(jù)庫時間序列間隔查詢方式

    這篇文章主要介紹了MySql數(shù)據(jù)庫時間序列間隔查詢方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • MySQL中字段類型為longtext的值導(dǎo)出后顯示二進(jìn)制串方式

    MySQL中字段類型為longtext的值導(dǎo)出后顯示二進(jìn)制串方式

    這篇文章主要介紹了MySQL中字段類型為longtext的值導(dǎo)出后顯示二進(jìn)制串方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • 詳細(xì)介紹windows下MySQL安裝教程

    詳細(xì)介紹windows下MySQL安裝教程

    這篇文章主要給大家介紹的是windows下MySQL安裝教程,其實(shí)好多公司,數(shù)據(jù)庫的面試題都是不可避免的,甚至一些前端工程師面試的時候都避免不了被詢問到和數(shù)據(jù)庫有關(guān)的一些問題。下面就從最基礎(chǔ)的安裝教程開始,需要的朋友可以參考一下
    2021-11-11
  • mysql MGR 單主多主模式切換知識點(diǎn)詳解

    mysql MGR 單主多主模式切換知識點(diǎn)詳解

    在本篇文章里小編給大家整理了關(guān)于mysql MGR 單主多主模式切換知識點(diǎn)詳解內(nèi)容,需要的朋友們可以參考下。
    2020-03-03
  • 如何利用MySQL的binlog恢復(fù)誤刪數(shù)據(jù)庫詳解

    如何利用MySQL的binlog恢復(fù)誤刪數(shù)據(jù)庫詳解

    MySQL一旦誤刪數(shù)據(jù)庫之后恢復(fù)數(shù)據(jù)很麻煩,這里記錄一下艱辛的恢復(fù)過程,這篇文章主要給大家介紹了關(guān)于如何利用MySQL的binlog恢復(fù)誤刪數(shù)據(jù)庫的相關(guān)資料,需要的朋友可以參考下
    2021-09-09
  • MySQL正則表達(dá)式REGEXP使用詳解

    MySQL正則表達(dá)式REGEXP使用詳解

    MySQL中正則表達(dá)式通常被用來檢索或替換符合某個模式的文本內(nèi)容,根據(jù)指定的匹配模式匹配文中符合要求的特殊字符串,下面這篇文章主要給大家介紹了關(guān)于MySQL正則表達(dá)式REGEXP使用的相關(guān)資料,需要的朋友可以參考下
    2022-09-09
  • wamp中mysql安裝時能啟動重啟后無法啟動的解決辦法

    wamp中mysql安裝時能啟動重啟后無法啟動的解決辦法

    這篇文章主要介紹了wamp中mysql安裝時能啟動重啟后無法啟動的解決辦法 ,需要的朋友可以參考下
    2018-08-08
  • MySQL權(quán)限USAGE和ALL PRIVILEGES的用法

    MySQL權(quán)限USAGE和ALL PRIVILEGES的用法

    本文主要介紹了MySQL權(quán)限USAGE和ALL PRIVILEGES的用法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-09-09
  • mysql8.0 用戶角色管理及授權(quán)的實(shí)現(xiàn)

    mysql8.0 用戶角色管理及授權(quán)的實(shí)現(xiàn)

    MySQL是一種常見的關(guān)系型數(shù)據(jù)庫管理系統(tǒng),它提供了強(qiáng)大的安全機(jī)制來管理用戶權(quán)限,本文主要介紹了mysql8.0 用戶角色管理及授權(quán)的實(shí)現(xiàn),具有一定的參考價值,感興趣的可以了解一下
    2024-04-04
  • MySQL導(dǎo)入.CSV數(shù)據(jù)中文亂碼的解決方式

    MySQL導(dǎo)入.CSV數(shù)據(jù)中文亂碼的解決方式

    當(dāng)將xls或xlsx文件轉(zhuǎn)換為CSV并導(dǎo)入數(shù)據(jù)庫時,可能出現(xiàn)亂碼,原因是編碼格式不是UTF-8,解決方法是使用Notepad或記事本打開CSV文件,所以本文給大家介紹了MySQL導(dǎo)入.CSV數(shù)據(jù)中文亂碼的解決方式,需要的朋友可以參考下
    2024-08-08

最新評論