日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

MySQL兩千萬數(shù)據(jù)優(yōu)化&遷移

瀏覽:41日期:2023-10-16 16:17:07

最近有一張2000W條記錄的數(shù)據(jù)表需要優(yōu)化和遷移。2000W數(shù)據(jù)對(duì)于MySQL來說很尷尬,因?yàn)楹侠淼膭?chuàng)建索引速度還是挺快的,再怎么優(yōu)化速度也得不到多大提升。不過這些數(shù)據(jù)有大量的冗余字段和錯(cuò)誤信息,極不方便做統(tǒng)計(jì)和分析。所以我需要?jiǎng)?chuàng)建一張新表,把舊表中的數(shù)據(jù)一條一條取出來優(yōu)化后放回新表;

一. 清除冗余數(shù)據(jù),優(yōu)化字段結(jié)構(gòu)

2000W數(shù)據(jù)中,能作為查詢條件的字段我們是預(yù)知的。所以將這部分?jǐn)?shù)據(jù)單獨(dú)創(chuàng)建新的字段,對(duì)于有規(guī)則的數(shù)據(jù)合理改變字段結(jié)構(gòu),比如身份證就是varchar(18)。對(duì)于不重要的數(shù)據(jù)我們合并后存在一個(gè)結(jié)構(gòu)為text的字段。

對(duì)于一些有關(guān)聯(lián)的數(shù)據(jù)我們需要計(jì)算,常見的比如身份證種能獲取到準(zhǔn)確的性別,出生地、生日、年齡。

二. 數(shù)據(jù)遷移

我們從數(shù)據(jù)庫中取出一條舊數(shù)據(jù),再通過計(jì)算處理后得到想要的新數(shù)據(jù),最后將新數(shù)據(jù)插入新表。不過在獲取新數(shù)據(jù)時(shí)遇到如下問題。

數(shù)據(jù)量太大,無法一次獲取(2000W數(shù)據(jù)扔到內(nèi)存挺可怕的);

我們可以通過MySQL的limit語法分批獲取。比如每次獲取50000,SQL語句如下:

select * from table_name limit 15000000,50000;

通過這種方法能解決數(shù)據(jù)量太大的問題,但是隨著limit的第一個(gè)參數(shù)越來越大,查詢速度會(huì)慢的嚇人(上面這條SQL執(zhí)行會(huì)花35秒)。時(shí)間就是生命,于是我們開始優(yōu)化SQL語句,優(yōu)化后變成下面這樣:

select * from table_name order by id desc limit 5000000,50000;

可通過二分法拆分2000W數(shù)據(jù),當(dāng)執(zhí)行到1000W數(shù)據(jù)時(shí),將數(shù)據(jù)倒序。優(yōu)化后SQL執(zhí)行效率顯著提升,從35秒降到9秒;

不過還是很慢,時(shí)間就是生命……還好我們有自增ID(創(chuàng)建數(shù)據(jù)表第一條定律,一定要有自增字段),優(yōu)化后的SQl如下:

1. select * from table_name where id>15000000 and id<15050000; 2. select * from table_name where id>15000000 limit 50000;

為了直觀演示,我寫了兩條功能一樣的SQL。相比第一條,第二條的limit會(huì)導(dǎo)致SQL的索引命中變差,效率同樣也會(huì)下降。第一條SQL的執(zhí)行時(shí)間是2毫秒,第二條執(zhí)行時(shí)間5毫秒(我取的平均值)。每次數(shù)據(jù)的查詢速度直接從35秒降到2毫秒……

數(shù)據(jù)量太大并且數(shù)據(jù)無法預(yù)估,某些特殊數(shù)據(jù)會(huì)導(dǎo)致數(shù)據(jù)導(dǎo)入失敗;

我們有三種方案去將新數(shù)據(jù)存入新表,分別如下:

一條一條插入數(shù)據(jù);

開始肯定會(huì)想這種方案一定不行,因?yàn)槊看尾迦攵紩?huì)有一次數(shù)據(jù)庫IO操作。但是該方案有個(gè)好處是能及時(shí)發(fā)現(xiàn)有問題的數(shù)據(jù),修改后再繼續(xù)執(zhí)行; 在Oracle中使用『綁定變量』能帶來性能提升,正好MySQL也提供了『綁定變量』的功能。于是在不改變邏輯的情況下,嘗試優(yōu)化數(shù)據(jù)存儲(chǔ)速度。代碼如下:

public function actionTest(array $data){ $mysqli = new mysqli('192.168.1.106', 'username', 'password', 'test'); $sql = 'insert into table_name(name,identity) values (?,?)'; $stmt = $connection->prepare($sql); $name = ''; $identity = ''; //使用綁定變量 $stmt->bind_param('si', $name, $identity); foreach($data as $val) {$name = $val[name];$identity = $val[card_id];//執(zhí)行$stmt->execute(); } $stmt->close();}

最后效果不怎么好,MySQL的『綁定變量』并沒帶來明顯的速度提升,不過能有效的防止SQL注入;

一次插入50000條數(shù)據(jù);

這是我最后選中的方案,一是能及時(shí)發(fā)現(xiàn)有問題的數(shù)據(jù),二是導(dǎo)入數(shù)據(jù)非常穩(wěn)定。就像支持?jǐn)帱c(diǎn)續(xù)傳一樣,每一步都能看到效果。在執(zhí)行腳本時(shí),也能同步開始寫分析邏輯;

組裝成SQL文件,最后統(tǒng)一導(dǎo)入;

組裝一個(gè)大的SQL文件,最后通過MySQL自帶的工具導(dǎo)入也是極好的。但如果有一條SQL有問題,你可能需要重跑一次腳本。因?yàn)樵?G大小的文本文件中修改一個(gè)符號(hào)是很痛苦的事情……

三. 總結(jié)

通過各種優(yōu)化,最后將腳本執(zhí)行時(shí)間縮短到了20分鐘內(nèi)。優(yōu)化后數(shù)據(jù)質(zhì)量得到了較高保證,下次將嘗試2億數(shù)據(jù)的優(yōu)化&遷移……

來自:https://yq.aliyun.com/articles/59907

標(biāo)簽: MySQL 數(shù)據(jù)庫
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲黄色网址| 国产丝袜一区| 久久人人99| 国产福利片在线观看| 日韩1区在线| 久久精品官网| 蜜臀久久99精品久久久画质超高清| 亚洲香蕉久久| 国产精品香蕉| 日韩欧美精品一区| 先锋亚洲精品| 国产精品一区高清| 91精品一区二区三区综合在线爱 | 羞羞答答国产精品www一本| 亚洲综合日韩| 日本免费新一区视频| 精品亚洲二区| 久久五月天小说| 日韩一区网站| 97视频热人人精品免费| 亚洲免费中文| 精品理论电影在线| 五月天综合网站| 国产欧美一区二区三区国产幕精品 | 国产精品99久久精品| 伊人精品一区| 久久激情综合网| 成人精品中文字幕| 日韩高清不卡一区二区| 91看片一区| 青草国产精品| 久久久久久久久丰满| 青青青国产精品| 国产专区一区| 麻豆国产欧美日韩综合精品二区| 一本一道久久a久久精品蜜桃| 国产女人18毛片水真多18精品| 久久精品av| 国产麻豆一区二区三区| 精品一区亚洲| 精品视频在线一区二区在线| 亚洲网址在线观看| 精品99在线| 日本亚洲视频| 99视频精品全国免费| 国产精品tv| 亚洲精品美女| 国产视频一区欧美| 欧美精品日日操| 国产精品啊v在线| 亚洲精品美女91| 红桃视频欧美| se01亚洲视频 | 国产日韩亚洲欧美精品| 伊人成人网在线看| 成人亚洲一区| 日韩和欧美一区二区| 啪啪国产精品| 精品国产三区在线| 欧美色综合网| 日韩欧美2区| 美女国产精品| 黑丝美女一区二区| 韩国精品主播一区二区在线观看 | 亚洲欧美视频| 欧美不卡视频| 久久久久99| 天堂av在线| 麻豆精品久久| 久久精品99国产精品| 亚洲精品乱码久久久久久蜜桃麻豆| 欧美特黄视频| 亚洲午夜91| 久久久久久久久久久妇女| 国产aⅴ精品一区二区三区久久| 国产日韩亚洲欧美精品| 91福利精品在线观看| 最近国产精品视频| 一区二区精品| 亚洲精品欧洲| 日本一区免费网站| 亚洲精品视频一二三区| 中文一区一区三区免费在线观| 五月婷婷六月综合| 亚洲激情久久| 午夜电影亚洲| 亚洲尤物在线| 美女91精品| 蜜桃久久精品一区二区| 日韩精品一级中文字幕精品视频免费观看| 欧美精品一线| 免播放器亚洲| 日韩中出av| 欧美日韩一区二区国产| 欧美在线日韩| 国产精品v日韩精品v欧美精品网站| 欧美综合精品| 美腿丝袜亚洲一区| 精品视频97| 欧美国产美女| 日韩精品一卡| 国产农村妇女精品一二区| 亚洲三级网站| 国产精品麻豆成人av电影艾秋| 国产情侣久久| а√天堂中文在线资源8| 性欧美videohd高精| 亚洲国产综合在线看不卡| 日韩亚洲国产欧美| 日欧美一区二区| 国产精品xvideos88| 日本激情一区| 好吊一区二区三区| 美女网站久久| 国产精品久久久久久久久免费高清 | zzzwww在线看片免费| 久久久水蜜桃av免费网站| 免费观看不卡av| 男女性色大片免费观看一区二区 | 日韩av自拍| 亚洲大片在线| 在线观看视频免费一区二区三区| 欧美日韩99| 蜜臀久久精品| 亚洲欧洲专区| 日韩伦理一区| 亚洲人成亚洲精品| 精品久久免费| 美女日韩在线中文字幕| 美女尤物国产一区| 五月婷婷六月综合| 国产精品观看| 欧美成人日韩| 日韩黄色在线观看| 成人国产精品| 蜜桃视频一区二区三区在线观看| 国产精品一线| 国精品一区二区三区| 国产美女久久| 欧美特黄视频| 狂野欧美性猛交xxxx| 午夜久久99| 久久99影视| 久久午夜视频| 国产一区二区三区四区| 日韩制服丝袜先锋影音| а√天堂8资源中文在线| 亚洲在线观看| 中文在线中文资源| 91精品丝袜国产高跟在线| 亚洲福利久久| 国产精品一页| 国产一级久久| 日韩欧美二区| 国产精区一区二区| 国产一区白浆| 国产成人精品亚洲日本在线观看| 日本亚洲最大的色成网站www | 亚洲精品无播放器在线播放| 日韩一区二区三区免费播放| 日韩中文av| 久久久久99| 国产va免费精品观看精品视频| 日韩精品久久久久久久软件91| 欧美1区2区3区| 国产精品久久观看| 欧美一区免费| 免费成人性网站| 99精品视频在线| 国产成人免费视频网站视频社区| 日韩av成人高清| 日韩精品一级中文字幕精品视频免费观看| 国产精品yjizz视频网| 日韩成人午夜精品| 噜噜噜躁狠狠躁狠狠精品视频| 日本韩国欧美超级黄在线观看| 欧美一区网站| 亚洲精品三级| 亚洲视频国产精品| av不卡免费看| 亚洲精品一区二区妖精| 成人免费网站www网站高清| 精品国产亚洲日本| 美女在线视频一区| 国产日韩欧美| 欧美日韩在线精品一区二区三区激情综合 | 首页国产欧美日韩丝袜| 久久久噜噜噜| 日韩中文首页| 欧美1区2区3| 国产精品丝袜在线播放| 欧美日本久久| 欧美日韩一区二区三区在线电影| 亚洲男人在线| 日韩在线麻豆| 日韩精品视频网站| 日本一区二区三区中文字幕| 亚洲综合小说| 亚洲1区在线观看| 亚久久调教视频|