AVt天堂网 手机版,亚洲va久久久噜噜噜久久4399,天天综合亚洲色在线精品,亚洲一级Av无码毛片久久精品

當前位置:首頁 > 科技  > 軟件

避免鎖表:為Update語句中的Where條件添加索引字段

來源: 責編: 時間:2024-05-27 08:57:35 133觀看
導讀最近在灰度環境中遇到一個問題:某項業務在創建數據時耗時異常長,但同樣的代碼在預發環境中并未出現此問題。起初我們以為是調用第三方接口導致的性能問題,但通過日志分析發現第三方接口的響應時間正常。最終,我們發現工單

最近在灰度環境中遇到一個問題:某項業務在創建數據時耗時異常長,但同樣的代碼在預發環境中并未出現此問題。起初我們以為是調用第三方接口導致的性能問題,但通過日志分析發現第三方接口的響應時間正常。最終,我們發現工單表的數據入庫SQL一直處于等待狀態。深入分析后,問題的核心暴露出來:另一業務流程中對工單表執行更新(UPDATE)操作的SQL,其where子句中涉及的字段缺少必要的索引,導致其他業務在操作表中的數據時需要等待該更新完成。今天就和大家分享一下這個經驗。i1W28資訊網——每日最新資訊28at.com

問題描述

mysql 修改數據時,如果where條件后的字段未加索引或者未命中索引會導致鎖表。這種鎖表行為會阻塞其他事務對該表的訪問,顯著降低并發性能和系統響應速度。i1W28資訊網——每日最新資訊28at.com

問題復現

我們在本地準備環境復現下,本地環境mysql使用的版本時8,首先準備一張表bus_pages,除了主鍵不創建其它索引,準備兩個接口,一個修改,一個新增i1W28資訊網——每日最新資訊28at.com

@Service@Slf4jpublic class BusTestServiceImpl implements BusTestService {    @Resource    private BusPagesService busPagesService;    @Override    @Transactional(rollbackFor = Exception.class)    public void updateInfo() {        StopWatch sw = new StopWatch();        sw.start();        log.info("修改方法執行開始");        LambdaUpdateWrapper<BusPagesEntity> updateWrapper = new LambdaUpdateWrapper();        updateWrapper.eq(BusPagesEntity::getMarkId,18);        updateWrapper.set(BusPagesEntity::getPage,LocalDateTime.now().toString());        busPagesService.update(updateWrapper);        try {            Thread.sleep(40*1000);        } catch (InterruptedException e) {            throw new RuntimeException(e);        }        sw.stop();        log.info("修改方法執行結束,耗時{}s",sw.getTime(TimeUnit.SECONDS));    }    @Override    public void saveInfo() {        StopWatch sw = new StopWatch();        sw.start();        log.info("新增方法執行開始");        BusPagesEntity busPagesEntity = new BusPagesEntity();        busPagesEntity.setPage(LocalDateTime.now().format(DateTimeFormatter.ISO_LOCAL_TIME));        busPagesService.save(busPagesEntity);        sw.stop();        log.info("新增方法執行結束,耗時{}s",sw.getTime(TimeUnit.SECONDS));    }}

我們首先調用修改方法,然后在調用新增方法,可以看到新增的接口會一直等待修改的接口完成之后才會執行完成。i1W28資訊網——每日最新資訊28at.com

圖片圖片i1W28資訊網——每日最新資訊28at.com

然后我們給表bus_pages的mark__id字段創建索引i1W28資訊網——每日最新資訊28at.com

圖片圖片i1W28資訊網——每日最新資訊28at.com

然后在執行修改及新增接口,可以看到新增接口不會在等待修改接口執行完在去執行了i1W28資訊網——每日最新資訊28at.com

圖片圖片i1W28資訊網——每日最新資訊28at.com

注意: 并不是創建了索引就不會鎖表,當我們的索引失效時,也會鎖表i1W28資訊網——每日最新資訊28at.com

命令行查看(mysql版本8.0)

  • 查看被鎖定的表
show OPEN TABLES where In_use > 0;

此命令用于列出當前正在使用中的表,也就是說那些被鎖定或正在進行某些操作(如讀寫操作)的表。i1W28資訊網——每日最新資訊28at.com

  • 查看正在等待鎖資源的查詢
select * from performance_schema.data_lock_waits;
select * from sys.innodb_lock_waits;
  • 查看鎖定數據
select * from performance_schema.data_locks;
  • 查看正在運行中的事務或命令的詳情
select * from information_schema.innodb_trx;

總結

在編寫Update語句時,務必注意Where條件中涉及的字段是否有索引支持。避免全表鎖的關鍵在于優化查詢,利用索引提高查詢效率,減少系統性能的影響。通過合理地設計索引,并確保Update語句中的Where條件包含索引字段,可以有效地提升數據庫的性能和并發能力。i1W28資訊網——每日最新資訊28at.com

本文鏈接:http://www.tebozhan.com/showinfo-26-90859-0.html避免鎖表:為Update語句中的Where條件添加索引字段

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: Java Nio FileChannel堆內堆外數據讀寫全流程分析及使用

下一篇: Go語言:利用Govaluate構建規則配置引擎

標簽:
  • 熱門焦點
  • K60至尊版狂暴引擎2.0加持:超177萬跑分斬獲性能第一

    Redmi的后性能時代戰略發布會今天下午如期舉辦,在本次發布會上,Redmi公布了多項關于和聯發科的深度合作,以及新機K60 Ultra在軟件和硬件方面的特性,例如:“K60 至尊版,雙芯旗艦
  • 跑分安卓第一!Redmi K60至尊版8月發布!盧偉冰:目標年度性能之王

    8月5日消息,Redmi K60至尊版將于8月發布,在此前舉行的戰略發布會上,官方該機將搭載搭載天璣9200+處理器,安兔兔V10跑分超177萬分,是目前安卓陣營最高的分數
  • 多線程開發帶來的問題與解決方法

    使用多線程主要會帶來以下幾個問題:(一)線程安全問題  線程安全問題指的是在某一線程從開始訪問到結束訪問某一數據期間,該數據被其他的線程所修改,那么對于當前線程而言,該線程
  • 一篇文章帶你了解 CSS 屬性選擇器

    屬性選擇器對帶有指定屬性的 HTML 元素設置樣式??梢詾閾碛兄付▽傩缘?HTML 元素設置樣式,而不僅限于 class 和 id 屬性。一、了解屬性選擇器CSS屬性選擇器提供了一種簡單而
  • Python異步IO編程的進程/線程通信實現

    這篇文章再講3種方式,同時講4中進程間通信的方式一、 Python 中線程間通信的實現方式共享變量共享變量是多個線程可以共同訪問的變量。在Python中,可以使用threading模塊中的L
  • 最“俊美”淘寶賣家,靠直播和短視頻圈粉,上架秒光,年銷3000萬

    來源 | 電商在線文|易琬玉編輯|斯問受訪店鋪:Ringdoll戒之人形圖源:微博@御座的黃山、&ldquo;Ringdoll戒之人形&rdquo;淘寶店鋪有關外貌的評價,黃山已經聽累了。生于1985年的他,哪
  • ESG的面子與里子

    來源 | 光子星球撰文 | 吳坤諺編輯 | 吳先之三伏大幕拉起,各地高溫預警不絕,但處于厄爾尼諾大&ldquo;烤&rdquo;之下的除了眾生,還有各大企業發布的ESG報告。ESG是&ldquo;環境保
  • 阿里大調整

    來源:產品劉有媒體報道稱,近期淘寶天貓集團啟動了近年來最大的人力制度改革,涉及員工績效、層級體系等多個核心事項,目前已形成一個初步的&ldquo;征求意見版&rdquo;:1、取消P序列
  • DRAM存儲器10月價格下跌,NAND閃存本月價格與上月持平

    10月30日,據韓國媒體消息,自今年年初以來一直在上漲的 DRAM 存儲器的交易價格僅在本月就下跌了近 10%,此次是全年首次降價,而NAND 閃存本月價格與上月持平。市
Top