欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python中MySQL數(shù)據(jù)遷移到MongoDB腳本的方法

 更新時間:2016年04月28日 16:52:39   作者:韓德田  
MongoDB 是一個介于關系數(shù)據(jù)庫和非關系數(shù)據(jù)庫之間的產(chǎn)品,是非關系數(shù)據(jù)庫當中功能最豐富,最像關系數(shù)據(jù)庫的。本文給大家介紹Python中MySQL數(shù)據(jù)遷移到MongoDB腳本的方法,需要的朋友參考下

MongoDB簡介

MongoDB 是一個基于分布式文件存儲的數(shù)據(jù)庫。由 C++ 語言編寫。旨在為 WEB 應用提供可擴展的高性能數(shù)據(jù)存儲解決方案。

MongoDB 是一個介于關系數(shù)據(jù)庫和非關系數(shù)據(jù)庫之間的產(chǎn)品,是非關系數(shù)據(jù)庫當中功能最豐富,最像關系數(shù)據(jù)庫的。

MongoDB是一個文檔數(shù)據(jù)庫,在存儲小文件方面存在天然優(yōu)勢。隨著業(yè)務求的變化,需要將線上MySQL數(shù)據(jù)庫中的行記錄,導入到MongoDB中文檔記錄。

一、場景:線上MySQL數(shù)據(jù)庫某表遷移到MongoDB,字段無變化。

二、Python模塊:

使用Python的torndb,pymongo和time模塊。

*注釋:首先安裝setup.py,pip,MySQLdb

執(zhí)行如下命令即可:

pip install torndb
pip install pymongo

三、腳本內(nèi)容如下:

[root ~]#cat nmytomongo.py

#!/usr/bin/env python#fielName: mytomongo.py#Author:xkops#coding: utf-8import torndb,pymongo,time# connect to mysql databasemysql = torndb.Connection(host='127.0.0.1', database='database', user='username', password='password')#connect to mongodb and obtain total lines in mysqlmongo = pymongo.MongoClient('mongodb://ip').databasemongo.authenticate('username',password='password')countlines = mysql.query('SELECT max(table_field) FROM table_name')count = countlines[0]['max(table_field)']#count = 300print counti = 0 j = 100start_time = time.time()#select from mysql to insert mongodb by 100 lines.for i in range(0,count,100): #print a,b #print i #print 'SELECT * FROM quiz_submission where quiz_submission_id > %d and quiz_submission_id <= %d' %(i,j) submission = mysql.query('SELECT * FROM table_name where table_field > %d and table_field <= %d' %(i,j)) #print submission if submission: #collection_name like mysql table_name mongo.collection_name.insert_many(submission) else: i +=100 j +=100 continue i +=100 j +=100end_time = time.time()deltatime = end_time - start_timetotalhour = int(deltatime / 3600)totalminute = int((deltatime - totalhour * 3600) / 60)totalsecond = int(deltatime - totalhour * 3600 - totalminute * 60)#print migrate data total time consuming.print "Data Migrate Finished,Total Time Consuming: %d Hour %d Minute %d Seconds" %(totalhour,totalminute,totalsecond)

*注釋:按照自己的需求更改上述代碼中的數(shù)據(jù)庫地址,用戶,密碼,庫名,表名以及字段名等。

四、執(zhí)行遷移腳本:

[root ~]#python nmytomongo.py &> /tmp/migratelog.txt &

腳本執(zhí)行完成后查看/tmp/migratelog.txt數(shù)據(jù)遷移消耗的時間。

相關文章

  • 關于Python形參打包與解包小技巧分享

    關于Python形參打包與解包小技巧分享

    今天小編就為大家分享一篇關于Python形參打包與解包小技巧分享,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-08-08
  • linux環(huán)境下安裝pyramid和新建項目的步驟

    linux環(huán)境下安裝pyramid和新建項目的步驟

    這篇文章簡單介紹了linux環(huán)境下安裝pyramid和新建項目的步驟,大家參考使用
    2013-11-11
  • wxpython 學習筆記 第一天

    wxpython 學習筆記 第一天

    wxPython是Python編程語言的一個GUI工具箱。他使得Python程序員能夠輕松的創(chuàng)建具有健壯、功能強大的圖形用戶界面的程序。
    2009-02-02
  • 深入解析Python的Tornado框架中內(nèi)置的模板引擎

    深入解析Python的Tornado框架中內(nèi)置的模板引擎

    模板引擎是Web開發(fā)框架中負責前端展示的關鍵,這里我們就來以實例深入解析Python的Tornado框架中內(nèi)置的模板引擎,來學習如何編寫Tonardo的模板.
    2016-07-07
  • python合并同類型excel表格的方法

    python合并同類型excel表格的方法

    這篇文章主要為大家詳細介紹了python合并同類型excel表格的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-04-04
  • python如何將mat文件轉為png

    python如何將mat文件轉為png

    這篇文章主要介紹了python如何將mat文件轉為png,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • python使用knn實現(xiàn)特征向量分類

    python使用knn實現(xiàn)特征向量分類

    這篇文章主要為大家詳細介紹了python使用knn實現(xiàn)特征向量分類,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • 時間序列重采樣和pandas的resample方法示例解析

    時間序列重采樣和pandas的resample方法示例解析

    這篇文章主要為大家介紹了時間序列重采樣和pandas的resample方法示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-09-09
  • Python 正則 re.compile 真的必需嗎

    Python 正則 re.compile 真的必需嗎

    本文主要介紹了Python 正則 re.compile 真的必需嗎,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-06-06
  • Python檢測網(wǎng)站鏈接是否已存在

    Python檢測網(wǎng)站鏈接是否已存在

    Python是一種解釋型、面向對象、動態(tài)數(shù)據(jù)類型的高級程序設計語言。通過本文給大家介紹Python檢測網(wǎng)站鏈接是否已存在的相關內(nèi)容,需要的朋友一起學習吧
    2016-04-04

最新評論