成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

MySQL兩千萬數據優化&遷移

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

最近有一張2000W條記錄的數據表需要優化和遷移。2000W數據對于MySQL來說很尷尬,因為合理的創建索引速度還是挺快的,再怎么優化速度也得不到多大提升。不過這些數據有大量的冗余字段和錯誤信息,極不方便做統計和分析。所以我需要創建一張新表,把舊表中的數據一條一條取出來優化后放回新表;

一. 清除冗余數據,優化字段結構

2000W數據中,能作為查詢條件的字段我們是預知的。所以將這部分數據單獨創建新的字段,對于有規則的數據合理改變字段結構,比如身份證就是varchar(18)。對于不重要的數據我們合并后存在一個結構為text的字段。

對于一些有關聯的數據我們需要計算,常見的比如身份證種能獲取到準確的性別,出生地、生日、年齡。

二. 數據遷移

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

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

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

select * from table_name limit 15000000,50000;

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

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

可通過二分法拆分2000W數據,當執行到1000W數據時,將數據倒序。優化后SQL執行效率顯著提升,從35秒降到9秒;

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

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

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

數據量太大并且數據無法預估,某些特殊數據會導致數據導入失敗;

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

一條一條插入數據;

開始肯定會想這種方案一定不行,因為每次插入都會有一次數據庫IO操作。但是該方案有個好處是能及時發現有問題的數據,修改后再繼續執行; 在Oracle中使用『綁定變量』能帶來性能提升,正好MySQL也提供了『綁定變量』的功能。于是在不改變邏輯的情況下,嘗試優化數據存儲速度。代碼如下:

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];//執行$stmt->execute(); } $stmt->close();}

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

一次插入50000條數據;

這是我最后選中的方案,一是能及時發現有問題的數據,二是導入數據非常穩定。就像支持斷點續傳一樣,每一步都能看到效果。在執行腳本時,也能同步開始寫分析邏輯;

組裝成SQL文件,最后統一導入;

組裝一個大的SQL文件,最后通過MySQL自帶的工具導入也是極好的。但如果有一條SQL有問題,你可能需要重跑一次腳本。因為在9G大小的文本文件中修改一個符號是很痛苦的事情……

三. 總結

通過各種優化,最后將腳本執行時間縮短到了20分鐘內。優化后數據質量得到了較高保證,下次將嘗試2億數據的優化&遷移……

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

標簽: MySQL 數據庫
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
久久众筹精品私拍模特| 色播五月激情综合网| 欧美在线综合视频| 亚洲成av人影院| 亚洲一区综合| 一区二区三区四区中文字幕| 1024精品一区二区三区| 亚洲欧洲精品一区二区三区| 欧美日韩视频| 国产精品色在线观看| 欧美 日韩 国产 一区| 26uuu另类欧美亚洲曰本| 成+人+亚洲+综合天堂| 3d成人动漫网站| 国精品**一区二区三区在线蜜桃| 欧美在线视频你懂得| 裸体一区二区三区| 欧美三级电影一区| 国产一区二区三区在线观看精品| 欧美日韩国产a| 国产剧情一区二区| 欧美一区二区视频在线观看| 国产精品一区二区在线播放 | 日韩三级伦理片妻子的秘密按摩| 国产成人无遮挡在线视频| 91精品国产综合久久久久| 国产黄色精品网站| 日韩欧美国产高清| 91日韩一区二区三区| 国产精品二三区| 亚洲人成久久| 午夜激情久久久| 欧美亚洲免费在线一区| 国产在线精品一区二区夜色 | 欧美日韩国产精品自在自线| 狠狠色综合播放一区二区| 欧美另类z0zxhd电影| 国产河南妇女毛片精品久久久| 91精品国产综合久久蜜臀| 不卡影院免费观看| 日本一区二区三区在线观看| 亚洲国产一区二区三区在线播| 亚洲一区二区三区四区五区黄| 噜噜噜在线观看免费视频日韩| 男女激情视频一区| 这里只有精品视频在线观看| 91在线精品一区二区三区| 17c精品麻豆一区二区免费| 国产精品久久波多野结衣| 免费成人av资源网| 日韩一区二区三区av| 欧美日本不卡| 一区二区三区波多野结衣在线观看| 免费日韩精品中文字幕视频在线| 日本不卡中文字幕| 日韩美女一区二区三区| 韩日午夜在线资源一区二区| 午夜精品久久一牛影视| 91精品欧美久久久久久动漫 | 狠狠色狠狠色综合人人| 一区二区激情小说| 欧美性生活久久| 成人性生交大片免费看中文网站| 国产精品全国免费观看高清| 久久久久一区| 成人免费看黄yyy456| 亚洲欧美一区二区三区孕妇| 欧美日韩一区二区三区四区五区| 欧美激情综合色综合啪啪| 亚洲成人先锋电影| 日韩精品专区在线影院重磅| 91久久国产综合久久蜜月精品| 麻豆91在线看| 久久久精品欧美丰满| 香蕉久久夜色| 成人精品视频一区二区三区| 亚洲精品视频在线观看免费| 欧美日韩和欧美的一区二区| 精品动漫av| 国模套图日韩精品一区二区| 中文字幕精品在线不卡| 91成人网在线| 国产精品二区三区四区| 美国十次综合导航| 国产精品免费久久| 欧美自拍丝袜亚洲| 欧美日本韩国一区二区三区| 秋霞电影网一区二区| 久久―日本道色综合久久 | 国产欧美日韩不卡| 久久不射2019中文字幕| 成人深夜视频在线观看| 亚洲成av人片一区二区三区| 精品99999| 可以看av的网站久久看| 99久久er热在这里只有精品66| 亚洲电影一区二区| 久久久久国产精品免费免费搜索| 久久精品一本| 女主播福利一区| 精品一区二区三区香蕉蜜桃 | 久久夜色精品一区| 久久久www免费人成黑人精品| 成人免费av网站| 婷婷丁香激情综合| 欧美激情中文字幕| 欧美久久久久免费| 校园激情久久| 色综合久久综合中文综合网| 美国毛片一区二区| 亚洲精品日韩综合观看成人91| 欧美mv和日韩mv国产网站| 裸体丰满少妇做受久久99精品| 欧美久久久久| 成人网页在线观看| 日韩成人一区二区三区在线观看| 国产精品久久久久久妇女6080| 884aa四虎影成人精品一区| 亚洲在线免费| 午夜国产欧美理论在线播放| 国产一区二区三区蝌蚪| 亚洲国产精品欧美一二99| 日本一区二区三区免费乱视频| 欧美精品一二三| 久久亚洲高清| 国产精品日本| 国产在线欧美日韩| 成人动漫精品一区二区| 精品一区二区国语对白| 亚洲一区二区av在线| 国产精品久久久久一区二区三区 | 国产精品地址| 成人午夜电影网站| 国产最新精品免费| 午夜精品在线视频一区| 最新国产精品久久精品| 久久久久久毛片| 欧美一二三四在线| 91精品福利视频| 午夜一级久久| 亚洲精品资源| 91啪九色porn原创视频在线观看| 国产九九视频一区二区三区| 日本视频一区二区三区| 亚洲国产精品久久艾草纯爱| 亚洲天天做日日做天天谢日日欢 | 精品国产亚洲在线| 欧美一区二区视频在线观看 | 国产精品福利在线播放| 久久久亚洲精品一区二区三区| 欧美一区二区三区在| 欧美性生活久久| 色视频成人在线观看免| 国产欧美一级| 亚洲精品社区| 亚洲另类黄色| 99pao成人国产永久免费视频| 欧美日韩亚洲一区二区三区四区| 99热国产精品| 99亚偷拍自图区亚洲| 成人午夜激情片| 欧美日韩精品是欧美日韩精品| 亚洲一区免费| 国产情侣久久| 亚洲黑丝一区二区| 国产综合亚洲精品一区二| 91香蕉视频黄| 99riav一区二区三区| 国产乱人伦精品一区二区在线观看 | 91精品国产综合久久久久久| 欧美在线观看视频在线| 欧美亚洲综合在线| 欧美日韩国产综合久久| 欧美日韩国产美女| 欧美一区二区三区免费观看视频| 在线不卡免费av| 欧美一级在线观看| 日韩欧美久久一区| 欧美成人欧美edvon| 日韩精品一区二| 亚洲精品一线二线三线无人区| 精品少妇一区二区三区视频免付费| 日韩一区二区电影在线| 精品国产3级a| 国产亚洲精品久| 国产精品久久久久婷婷| 亚洲色图一区二区三区| 伊人一区二区三区| 亚洲高清在线视频| 美女网站在线免费欧美精品| 国产乱码精品1区2区3区| 成人黄色在线视频| 色综合网站在线| 欧美精品一区在线| 亚洲欧洲在线一区| 日本久久一区二区三区| 6080国产精品一区二区| 久久久久99精品国产片| 亚洲欧美日韩系列| 免费视频一区二区|