色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Mysql存儲(chǔ)過(guò)程如何實(shí)現(xiàn)歷史數(shù)據(jù)遷移

瀏覽:131日期:2023-02-18 16:43:24
目錄
  • Mysql遷移歷史數(shù)據(jù)
    • 需求陳述
    • 心路歷程
    • 最終實(shí)現(xiàn)
  • 總結(jié)

    Mysql遷移歷史數(shù)據(jù)

    記錄一下工作中由于業(yè)務(wù)需要以及系統(tǒng)的數(shù)據(jù)庫(kù)模型變更,導(dǎo)致需要做一下歷史數(shù)據(jù)遷移的解決辦法

    需求陳述

    • 一共涉及到三張表,分別稱為A、B、C
    • 歷史數(shù)據(jù)在表A中。
    • A表中存的數(shù)據(jù)有兩部分,通過(guò)一個(gè)busi_reg_province_code 字段來(lái)區(qū)分
    • 一部分插入到B表,一部分插入到C表(就是用busi_reg_province_code來(lái)區(qū)分的兩部分)
    • 存入B中的部分,對(duì)于存入C中的部分是一對(duì)多的關(guān)系。(相當(dāng)于B是做個(gè)匯總,C是詳細(xì)情況)
    • 存入B的要計(jì)算存入C的某一字段值的總和

    其實(shí)就是將一張表中的數(shù)據(jù),拆分分別存入B和C中。但是B和C是一對(duì)多的關(guān)系。

    心路歷程

    Step1

    • 說(shuō)到數(shù)據(jù)遷移,第一想法就是通過(guò)insert into select 的語(yǔ)法形式來(lái)做數(shù)據(jù)遷移。
    • 但是因?yàn)锽是C數(shù)據(jù)的匯總,所以不免需要使用一些聚合函數(shù)做計(jì)算,還要分組。
    • 嗯~想想就頭大。
    • 嘗試著寫(xiě)了一下以后,最后還是放棄了。(突然覺(jué)得自己對(duì)SQL是一無(wú)所知,菜的摳jio

    Step2

    • 放棄了寫(xiě)SQL,怎么辦呢?需求還得做。
    • 那作為一名JAVA開(kāi)發(fā),于是寫(xiě)一個(gè)接口的想法誕生了。
    • 整理一下思路,發(fā)現(xiàn)用JAVA寫(xiě),嗯~(會(huì)心一笑)還是很容易的。
    • 畢竟java8的流式處理還是很方便的。但是就在這時(shí),心里突然又覺(jué)得 emm~ 我這樣逃避好像也不好啊。
    • 沒(méi)有長(zhǎng)進(jìn)都,而且這個(gè)接口就調(diào)用一次,屬實(shí)是有點(diǎn)不合適。
    • 所以覺(jué)得還是放棄JAVA方式。

    Step3

    • 既然還是用SQL語(yǔ)句來(lái)寫(xiě),但是什么sum、count、group by、case when 摻在一起又那么復(fù)雜又理不清,可咋辦呢?
    • 那只好 必應(yīng)一下。剛好查到了存儲(chǔ)結(jié)構(gòu)
    • 但是此時(shí)思想還是停留在insert into select 的階段,但是因?yàn)橹麈I并不是自增的,這個(gè)主鍵的問(wèn)題得解決。

    整理一下問(wèn)題:

    • 主鍵非自增,所以怎么賦值?
    • 需要計(jì)算總值的列怎么計(jì)算?
    • 怎么能寫(xiě)一個(gè)SQL把兩個(gè)表都插入完成?

    上面這幾個(gè)問(wèn)題一出現(xiàn),似乎已經(jīng)沒(méi)辦法再使用insert into select的形式了。

    所以只能一個(gè)一個(gè)循環(huán)處理。那怎么循環(huán)呢?

    這個(gè)時(shí)候就行到了游標(biāo)。可是這兩個(gè)東西,不管是觸發(fā)器,還是游標(biāo)這個(gè)技能都已經(jīng)封存已久,一點(diǎn)不記得了。所以重新學(xué)習(xí)一下

    學(xué)習(xí)參考了一下這個(gè)文章。我覺(jué)得寫(xiě)的還是蠻細(xì)致的

    最終實(shí)現(xiàn)

    下面是我最終寫(xiě)完的存儲(chǔ)過(guò)程。用了游標(biāo)的嵌套

    #  --------------------------歷史數(shù)據(jù)遷移----------------------
    # 刪除存儲(chǔ)過(guò)程
    drop procedure if exists convertHistory;
    # 創(chuàng)建一個(gè)存儲(chǔ)過(guò)程
    create procedure convertHistory()
    begin
      #   定義一個(gè)主鍵
      declare outerId bigint default (select min(RESOURCE_ID) from mkt_resource_conf);
      # 定義查詢插入的列
      declare caseName varchar(32);
      declare gradeId varchar(32);
      declare flowGrade bigint(10);
      declare allocateNum bigint(10);
      declare province varchar(8);
      declare flowUnit varchar(4);
      #   是否完成
      declare done int default false;
      # 創(chuàng)建游標(biāo)
      declare orignData cursor for select CASE_NAME,
          FLOW_GRADE,
          GRADE_ID,
          QUANTITY,
          BUSI_REG_PROVINCE_CODE,
          FLOW_UNIT
           from prd_flow_info
           where BUSI_REG_PROVINCE_CODE = "100";
      #   指定游標(biāo)循環(huán)結(jié)束時(shí)的返回值
      declare continue HANDLER FOR not found set done = true;
      #   把初始值ID減一個(gè)數(shù)目
      set outerId = outerId - 100;
      #   先把之前遷移的刪掉
      delete from mkt_resource_conf where REMARK = "歷史數(shù)據(jù)割接";
      #     刪掉之前的
      delete from mkt_resource_store_conf where REMARK = "歷史數(shù)據(jù)割接";
      # 打開(kāi)游標(biāo)
      open orignData;
      fetch orignData into caseName,flowGrade,gradeId,allocateNum,province,flowUnit;
      while (not done) do
      #     具體的業(yè)務(wù)邏輯
      #     查詢的都是配置項(xiàng),那么插入到配置表
      #     配置項(xiàng)需要查詢一下該配置的總量
      select sum(QUANTITY)
      from prd_flow_info
      where FLOW_GRADE = flowGrade
        and BUSI_REG_PROVINCE_CODE = "99" into allocateNum;
      #     1、2G 的流量直接做轉(zhuǎn)換,轉(zhuǎn)為MB
      if flowUnit = "G" then
        set flowGrade = flowGrade * 1024;
      end if;
    
      insert into mkt_resource_conf
      values (outerId, caseName, gradeId, flowGrade, allocateNum, allocateNum, 1, "沒(méi)什么說(shuō)明", "system", "system", sysdate(),
      "system", "system",
      sysdate(), "1", "歷史數(shù)據(jù)割接");
      #     查詢門(mén)店的配置,并且插入到門(mén)店的配置信息表
      #     這里就要寫(xiě)一個(gè)嵌套的游標(biāo)了
      begin
        #       定義一個(gè)配置表的ID
        declare storeConfId bigint default (select min(STORE_CONF_ID) from mkt_resource_store_conf);
        declare storeCode varchar(32);
        declare alloNum bigint(10);
        declare usedNum bigint(10);
        declare storeDone int default false;
        declare storeName varchar(128);
        #     定義游標(biāo)
        declare storeData cursor for select store_code,QUANTITY,USE_NUM
     from prd_flow_info
     where GRADE_ID = gradeId
       and BUSI_REG_PROVINCE_CODE = "99";
        declare continue HANDLER FOR not found set storeDone = true;
        #     select gradeId;
    
        set storeConfId = storeConfId - 100;
    
        # 開(kāi)始游標(biāo)了
        open storeData;
        fetch storeData into storeCode,alloNum,usedNum;
    
        while (not storeDone) do
        #       從表里查一下storeName,沒(méi)有就沒(méi)轍了
        select STORE_NAME from mkt_resource_store_conf where STORE_CODE = storeCode limit 1 into storeName;
        #       開(kāi)始保存到門(mén)店配置表
        insert into `mkt_resource_store_conf` (`store_conf_id`, `resource_id`, `store_code`, `STORE_NAME`,
       `allocated_res_num`,
       `used_res_num`,
       `create_id`, `create_name`, `create_time`, `update_id`, `update_name`,
       `update_time`,
       `state`, `remark`)
        values (storeConfId, outerId, storeCode, storeName, alloNum, usedNum, "system", "system", sysdate(), "system",
        "system",
        sysdate(),
        1, "歷史數(shù)據(jù)割接");
        commit ;
        #       ID -1
        set storeConfId = storeConfId - 1;
        fetch storeData into storeCode,alloNum,usedNum;
        end while;
        #     重置變量
        set storeDone = false;
        #     關(guān)閉內(nèi)層游標(biāo)
        close storeData;
      end;
      #   把初始值ID減一
      set outerId = outerId - 1;
      fetch orignData into caseName,flowGrade,gradeId,allocateNum,province,flowUnit;
      end while;
      #   關(guān)閉游標(biāo)
      close orignData;
    
      SELECT * FROM mkt_resource_conf where REMARK = "歷史數(shù)據(jù)割接";
      SELECT * FROM mkt_resource_store_conf where REMARK = "歷史數(shù)據(jù)割接";
    end;
    
    call convertHistory();
    

    總結(jié)

    沒(méi)開(kāi)始的時(shí)候覺(jué)得會(huì)很難,但是真的邊學(xué)邊寫(xiě)的時(shí)候,心情就會(huì)逐漸轉(zhuǎn)變。萬(wàn)事開(kāi)頭難說(shuō)的不錯(cuò),一旦開(kāi)始獲得正向反饋,問(wèn)題也就慢慢的迎刃而解了。

    其實(shí)這個(gè)寫(xiě)的并不復(fù)雜,只是代碼比較長(zhǎng)。

    總結(jié)一下:

    • 首先要克服自己的心里恐懼
    • 定義存儲(chǔ)過(guò)程的語(yǔ)法declare procedure
    • 了解游標(biāo)及存儲(chǔ)過(guò)程的使用場(chǎng)景
    • 定義游標(biāo)的過(guò)程declare 游標(biāo)名 cursor for (select 語(yǔ)句)
    • 打開(kāi)游標(biāo)open 游標(biāo)名 關(guān)閉游標(biāo)close 游標(biāo)名
    • 將游標(biāo)中查詢的字段事先定義好,然后通過(guò)fetch 游標(biāo)名 into 事先定義的變量 來(lái)獲得每一條數(shù)據(jù)(有點(diǎn)像ES6的generator,走一步踢一腳)
    • 變量賦值select xxx into 變量set xxx = 變量值
    • 其他的就是條件控制語(yǔ)句loop 、while、if、else

    總的來(lái)說(shuō)掌握基本語(yǔ)法,或者看一眼別人的格式,就可以模仿出來(lái)了。

    以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持。

    標(biāo)簽: MySQL
    相關(guān)文章:
    主站蜘蛛池模板: 成人毛片网站 | 欧美一级片在线视频 | 日本一本黄 | 手机午夜看片 | 久久看片网 | 久草资源网站 | 成人三级视频在线观看 | 久久精品一 | 国产一区二区三区免费播放 | 日本高清在线不卡 | 久久精品国产99精品最新 | 天堂一区二区在线观看 | 自拍国内| 日韩国产成人资源精品视频 | 亚洲精品自拍视频 | 国产成人精品日本亚洲麻豆 | 亚洲欧美第一 | 一级特黄一欧美俄罗斯毛片 | 日韩高清一级毛片 | 男人毛片 | 男女一级爽爽快视频 | 国产第一页在线观看 | 国内自拍亚洲 | 91久久国产精品 | 亚洲小视频网站 | 亚洲女精品一区二区三区 | 国产韩国精品一区二区三区久久 | 免费看又黄又爽又猛的网站 | 欧美大片aaaa一级毛片 | 国产成人免费在线观看 | 日韩欧美一区二区三区不卡视频 | 一级片国产 | 亚洲国产激情一区二区三区 | 亚洲视频一区在线 | 成人禁在线观看网站 | 在线亚洲精品国产成人二区 | 欧美在线观看一区二区 | 特级毛片aaaa级毛片免费 | 久久综合九九亚洲一区 | 久久欧美成人精品丝袜 | 国产一区二区三区免费在线视频 |