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

MySQL多個(gè)表的關(guān)聯(lián)字段實(shí)現(xiàn)同步更新的解決方案

 更新時(shí)間:2024年11月19日 11:50:42   作者:離開地球表面_99  
在對(duì)數(shù)據(jù)庫表結(jié)構(gòu)進(jìn)行設(shè)計(jì)時(shí),為了提高查詢效率,會(huì)進(jìn)行一些反規(guī)范化設(shè)計(jì),如:設(shè)計(jì)一些冗余字段,但這樣可能會(huì)存在數(shù)據(jù)同步問題,故本文給大家介紹了MySQL多個(gè)表的關(guān)聯(lián)字段實(shí)現(xiàn)同步更新的解決方案,需要的朋友可以參考下

1. 背景

在對(duì)數(shù)據(jù)庫表結(jié)構(gòu)進(jìn)行設(shè)計(jì)時(shí),為了提高查詢效率,會(huì)進(jìn)行一些反規(guī)范化設(shè)計(jì),如:設(shè)計(jì)一些冗余字段。但這樣可能會(huì)存在數(shù)據(jù)同步問題,當(dāng)源表字段值更新時(shí),冗余字段值也需要同步更新。

現(xiàn)有產(chǎn)品表 product ,移動(dòng)端版本 mobile_version ,授權(quán)綁定產(chǎn)品表auth_server_product 三個(gè)表,這三個(gè)表有一個(gè)共同字段 productName,期望當(dāng) product 表中的 productName 字段的值改變時(shí),將該字段修改后的值同步更新到 mobile_version,auth_server_product 兩個(gè)表中。

1.1 表結(jié)構(gòu)定義

1.1.1 product 表

CREATE TABLE `product`  (
  `id` int(0) NOT NULL AUTO_INCREMENT,
  `productName` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL,
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;

INSERT INTO `product` VALUES (1, '產(chǎn)品A');
INSERT INTO `product` VALUES (2, '產(chǎn)品B');
INSERT INTO `product` VALUES (3, '產(chǎn)品C');

1.1.2 auth_server_product 表

CREATE TABLE `auth_server_product`  (
  `id` int(0) NOT NULL,
  `authId` int(0) NULL DEFAULT NULL,
  `productId` int(0) NULL DEFAULT NULL,
  `productName` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL,
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;

INSERT INTO `auth_server_product` VALUES (1, 1, 1, '產(chǎn)品A');
INSERT INTO `auth_server_product` VALUES (2, 1, 2, '產(chǎn)品B');
INSERT INTO `auth_server_product` VALUES (3, 1, 3, '產(chǎn)品C');

1.1.3 mobile_version 表

CREATE TABLE `mobile_version`  (
  `id` int(0) NOT NULL,
  `mobile_version` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL,
  `productId` int(0) NULL DEFAULT NULL,
  `productName` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL,
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;


INSERT INTO `mobile_version` VALUES (1, 'V1.0.0', 1, '產(chǎn)品A');
INSERT INTO `mobile_version` VALUES (2, 'V1.0.1', 1, '產(chǎn)品A');

2. 解決方案

2.1 應(yīng)用層代碼中更新

代碼層實(shí)現(xiàn)數(shù)據(jù)同步邏輯,在更新 product 表中的 productName 字段時(shí),同步更新auth_server_product 與 mobile_version 兩表中的字段值。大致邏輯如下:

@Transactional
public void updateProductName(String oldProductName, String newProductName) {
    // 更新 product 表中的 productName
    productRepository.updateProductName(oldProductName, newProductName);
    
    // 同步更新 mobile_version 表
    mobileVersionRepository.updateProductName(oldProductName, newProductName);

    // 同步更新 auth_server_product 表
    authServerProductRepository.updateProductName(oldProductName, newProductName);
}

該種方案的劣勢(shì)

  • 代碼復(fù)雜,耦合性強(qiáng);
  • 數(shù)據(jù)不一致:如果同步邏輯沒有被正確實(shí)現(xiàn)或處理,可能會(huì)導(dǎo)致數(shù)據(jù)不一致。

2.2 利用MySQL提供的觸發(fā)器功能

MySQL 提供了觸發(fā)器功能,在隨某個(gè)表進(jìn)行記錄的新增(INSERT)、修改(UPDATE) 或是刪除( DELETE) 操作時(shí),會(huì)自動(dòng)觸發(fā)相應(yīng)的操作。

針對(duì)上述場(chǎng)景中的這個(gè)問題,可以在 product 表設(shè)置觸發(fā)器,在 UPDATE 操作時(shí),通過觸發(fā)器來同步更新 mobile_versionauth_server_product 表中的 productName 字段。

2.2.1 具體實(shí)現(xiàn)

Navicat 為例進(jìn)行演示

Step 1 : 創(chuàng)建觸發(fā)器

設(shè)計(jì) procut 表,點(diǎn)擊觸發(fā)器,定義觸發(fā)器的名稱,類型選擇AFTER UPDATE,表示在product 表中的 productName 更新后 同步更新其他表。

Step 2 : SQL 定義觸發(fā)器行為

編寫具體的SQL語句定義觸發(fā)器行為,在這個(gè)例子中,期望在 productName 更新時(shí),自動(dòng)更新 mobile_versionauth_server_product 表中的 productName。SQL 下:

BEGIN
    -- 如果 productName 發(fā)生變化
    IF OLD.productName <> NEW.productName THEN
        -- 更新 mobile_version 表中的 productName
        UPDATE mobile_version
        SET productName = NEW.productName
        WHERE productName = OLD.productName;
        
        -- 更新 auth_server_product 表中的 productName
        UPDATE auth_server_product
        SET productName = NEW.productName
        WHERE productName = OLD.productName;
    END IF;
END 

Step 3 : 驗(yàn)證

  • show triggers,可查看當(dāng)前數(shù)據(jù)庫中的觸發(fā)器,驗(yàn)證觸發(fā)器是否創(chuàng)建成功。

  • 執(zhí)行更新語句,驗(yàn)證觸發(fā)器的定義能否達(dá)到期望的效果。
update product set productName = '產(chǎn)品AA' where id = '1'

可以看到,當(dāng) product 表中的 productName 值更新后,mobile_version 與 auth_server_product 對(duì)應(yīng)的 productName 值同步更新。

2.2.2 關(guān)于觸發(fā)器

  • 觸發(fā)事件:觸發(fā)器會(huì)在某個(gè)特定事件發(fā)生時(shí)被觸發(fā)。常見的觸發(fā)事件包括:

    • INSERT:在插入數(shù)據(jù)時(shí)觸發(fā)。
    • UPDATE:在更新數(shù)據(jù)時(shí)觸發(fā)。
    • DELETE:在刪除數(shù)據(jù)時(shí)觸發(fā)。
  • 觸發(fā)時(shí)機(jī):觸發(fā)器可以定義在數(shù)據(jù)事件發(fā)生的 BEFORE)或 AFTER)執(zhí)行。

    • BEFORE:觸發(fā)器在數(shù)據(jù)變更之前執(zhí)行。
    • AFTER:觸發(fā)器在數(shù)據(jù)變更之后執(zhí)行。
  • 觸發(fā)器的作用域:觸發(fā)器通常綁定到某個(gè)表上,并且只能在該表的數(shù)據(jù)操作時(shí)觸發(fā)。它不能跨表執(zhí)行,也不能直接返回?cái)?shù)據(jù)。

以上就是MySQL多個(gè)表的關(guān)聯(lián)字段實(shí)現(xiàn)同步更新的解決方案的詳細(xì)內(nèi)容,更多關(guān)于MySQL關(guān)聯(lián)字段同步更新的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • SQL中EXPLAIN命令的使用方法

    SQL中EXPLAIN命令的使用方法

    這篇文章主要給大家介紹了關(guān)于SQL中EXPLAIN命令的使用方法,文中介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • MySQLJSON索引用法舉例簡(jiǎn)單介紹

    MySQLJSON索引用法舉例簡(jiǎn)單介紹

    索引是一個(gè)數(shù)據(jù)結(jié)構(gòu),索引是幫助MySQL高效獲取數(shù)據(jù)的數(shù)據(jù)結(jié)構(gòu)(有序),這篇文章主要給大家介紹了關(guān)于MySQLJSON索引用法的相關(guān)資料,需要的朋友可以參考下
    2024-01-01
  • MySQL執(zhí)行事務(wù)的語法與流程詳解

    MySQL執(zhí)行事務(wù)的語法與流程詳解

    這篇文章主要介紹了MySQL執(zhí)行事務(wù)的語法與流程的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • Windows下mysql5.7.21安裝詳細(xì)教程

    Windows下mysql5.7.21安裝詳細(xì)教程

    這篇文章主要為大家詳細(xì)介紹了Windows下mysql5.7.21安裝詳細(xì)教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-02-02
  • CentOS下編寫shell腳本來監(jiān)控MySQL主從復(fù)制的教程

    CentOS下編寫shell腳本來監(jiān)控MySQL主從復(fù)制的教程

    這篇文章主要介紹了在CentOS系統(tǒng)下編寫shell腳本來監(jiān)控主從復(fù)制的教程,文中舉了兩個(gè)發(fā)現(xiàn)故障后再次執(zhí)行復(fù)制命令的例子,需要的朋友可以參考下
    2015-12-12
  • pycharm2017實(shí)現(xiàn)python3.6與mysql的連接

    pycharm2017實(shí)現(xiàn)python3.6與mysql的連接

    這篇文章主要為大家詳細(xì)介紹了PyCharm連接MySQL數(shù)據(jù)庫的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-03-03
  • mysql_fetch_row()與mysql_fetch_array()的使用介紹

    mysql_fetch_row()與mysql_fetch_array()的使用介紹

    本篇文章是對(duì)mysql_fetch_row()與mysql_fetch_array()的使用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • Mysql用戶創(chuàng)建以及權(quán)限賦予操作的實(shí)現(xiàn)

    Mysql用戶創(chuàng)建以及權(quán)限賦予操作的實(shí)現(xiàn)

    在MySQL中,創(chuàng)建新用戶并為其授予權(quán)限是一項(xiàng)常見的操作,本文主要介紹了Mysql用戶創(chuàng)建以及權(quán)限賦予操作的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-10-10
  • Mysql8創(chuàng)建用戶及賦權(quán)操作實(shí)戰(zhàn)記錄

    Mysql8創(chuàng)建用戶及賦權(quán)操作實(shí)戰(zhàn)記錄

    一般在開發(fā)中,我們需要新建一個(gè)賬戶,并賦予某個(gè)數(shù)據(jù)庫的訪問權(quán)限,下面這篇文章主要給大家介紹了關(guān)于Mysql8創(chuàng)建用戶及賦權(quán)操作的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-04-04
  • MySQL實(shí)例精講單行函數(shù)以及字符數(shù)學(xué)日期流程控制

    MySQL實(shí)例精講單行函數(shù)以及字符數(shù)學(xué)日期流程控制

    SQL函數(shù)即數(shù)據(jù)庫的內(nèi)置函數(shù),可以運(yùn)用在SQL語句中實(shí)現(xiàn)特定的功能。SQL單行函數(shù)對(duì)于每一行數(shù)據(jù)進(jìn)行計(jì)算后得到一行輸出結(jié)果。SQL單行函數(shù)根據(jù)數(shù)據(jù)類型分為字符函數(shù)、數(shù)字函數(shù)、日期函數(shù)、轉(zhuǎn)換函數(shù),另外還有一些別的函數(shù)
    2021-10-10

最新評(píng)論