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

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

MySQL兩千萬數據優化&遷移

瀏覽:43日期: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 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美日韩国产一区二区三区不卡| 岛国精品一区| 免费精品一区| 国产在线成人| 麻豆国产精品一区二区三区| 欧美美女一区| 免费在线成人| 日韩中文字幕视频网| 久久久久一区| 精品国产精品久久一区免费式| 欧美色综合网| 欧美在线亚洲| 亚洲精品在线影院| 久久免费精品| 国产精品多人| 国产精品xxx在线观看| 亚洲欧美日韩国产一区| 日韩av福利| 久久五月天小说| 在线天堂资源www在线污| 99精品在线观看| 精品伊人久久| 都市激情国产精品| 韩国久久久久久| 久久久久免费av| 免播放器亚洲| 日韩福利视频网| 婷婷五月色综合香五月| 亚洲欧洲国产精品一区| 日韩精选在线| 国产一区福利| 亚洲成人不卡| 国产精品免费看| 国产日韩在线观看视频| 欧美aa在线视频| 色老板在线视频一区二区| 欧美中文字幕一区二区| 午夜国产一区二区| 蜜臀久久久99精品久久久久久| 欧美日本不卡| 97精品中文字幕| 免费看黄色91| 久久永久免费| 免费成人av在线播放| 麻豆一区二区三| 99在线|亚洲一区二区| 国产丝袜一区| 久久久噜噜噜| 毛片不卡一区二区| 国产精品美女久久久浪潮软件| 欧美国产另类| 亚洲一区二区三区高清| 国产精品一线天粉嫩av| 青青久久av| 日本精品在线播放| 好看不卡的中文字幕| 久久99影视| 91福利精品在线观看| 亚洲一区国产| 今天的高清视频免费播放成人| 欧美黄页在线免费观看| 午夜性色一区二区三区免费视频| 亚洲一区资源| 激情综合五月| 国产精东传媒成人av电影| 亚洲精品护士| 免费人成精品欧美精品| 精品视频91| 欧美国产另类| 国产精品宾馆| 精品高清久久| 97视频热人人精品免费| 国产精品精品| 黄色在线观看www| 欧美aa在线观看| 婷婷成人在线| 九九综合九九| 亚洲一区二区三区四区五区午夜 | 尤物在线精品| 亚洲二区精品| 丝瓜av网站精品一区二区| 久久精品青草| 美女91精品| 欧美一区网站| 国产a久久精品一区二区三区| 中文在线а√天堂| 国产精品毛片在线看| 日韩一区二区三区高清在线观看| 91福利精品在线观看| 日韩一区网站| 里番精品3d一二三区| 精品亚洲美女网站| 日韩在线一区二区| 精品深夜福利视频| 欧美日韩在线观看视频小说| 亚洲深夜福利在线观看| 91亚洲精品视频在线观看 | 国产精品久久久久av电视剧| 免费av一区| 国产精品主播在线观看| 99精品小视频| 国产精品qvod| 999久久久91| 国产精品日本一区二区不卡视频| 日韩精品中文字幕第1页| 在线精品一区二区| 久久毛片亚洲| 国产三级一区| 国产精品美女久久久| 精品免费视频| 日韩av一区二区三区四区| 日韩中文首页| 国产日韩一区二区三区在线| 日韩亚洲在线| 国产99亚洲| 97精品国产福利一区二区三区| 日韩免费精品| 日韩欧美综合| 精品三级国产| 国产剧情在线观看一区| 中文字幕一区日韩精品| 蜜臀久久99精品久久一区二区 | 日韩视频一区| 99久久亚洲精品| 91av亚洲| 成人va天堂| 精精国产xxxx视频在线野外| 麻豆91小视频| 国产麻豆一区二区三区 | 国产伦精品一区二区三区在线播放| 99re国产精品| 国产精品美女| 日韩制服丝袜先锋影音| 日韩午夜黄色| 亚州av日韩av| 欧美亚洲专区| 国产精品theporn| 黄毛片在线观看| 国产一区清纯| 亚洲欧美网站| 欧美天堂在线| 国产在线观看www| 精品在线91| 日韩精品视频网| 911精品国产| 精品视频在线观看网站| 高清日韩欧美| 日韩视频中文| 国产精成人品2018| 久久久久99| 日韩高清一区| 国产69精品久久| 免费日韩视频| 欧美aaaaaa午夜精品| 国产99久久| 国产图片一区| 国内亚洲精品| 国产精品99精品一区二区三区∴| 久久久天天操| 美女国产一区| 欧美国产免费| 美女91精品| 久久九九国产| 欧美国产先锋| 久色成人在线| 成人久久久久| 国产成人免费精品| 中文字幕日韩亚洲| 99tv成人| 国产免费播放一区二区| 国产一区91| 亚洲高清成人| 国产91在线精品| 国产精品99久久免费| 一本一道久久a久久精品蜜桃| 麻豆91小视频| 国产精品一区二区99| 中文无码日韩欧| 红桃视频国产精品| 日本欧美不卡| 中文字幕在线免费观看视频| 久久激五月天综合精品| 亚洲香蕉久久| 中文在线一区| 夜夜精品视频| 婷婷综合亚洲| 一本一本久久| 亚洲性视频在线| 亚洲欧美日韩视频二区| 久久中文字幕av| 日韩免费一区| 欧美日韩在线网站| 97人人精品| 亚洲伊人av| 午夜欧美精品久久久久久久| 91高清一区| 午夜久久av | 亚洲免费激情| 久久亚洲一区| 国产日韩亚洲欧美精品|