位置: 编程技术 - 正文

Python中MySQL数据迁移到MongoDB脚本的方法

编辑:rootadmin

推荐整理分享Python中MySQL数据迁移到MongoDB脚本的方法,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

MongoDB简介

MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。

MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。

MongoDB是一个文档数据库,在存储小文件方面存在天然优势。随着业务求的变化,需要将线上MySQL数据库中的行记录,导入到MongoDB中文档记录。

一、场景:线上MySQL数据库某表迁移到MongoDB,字段无变化。

二、Python模块:

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

*注释:首先安装setup.py,pip,MySQLdb

Python中MySQL数据迁移到MongoDB脚本的方法

执行如下命令即可:

pip install torndbpip install pymongo

三、脚本内容如下:

[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='.0.0.1', database='database', user='username', password='password')#connect to mongodb and obtain total lines in mysqlmongo = pymongo.MongoClient(' = mysql.query('SELECT max(table_field) FROM table_name')count = countlines[0]['max(table_field)']#count = print counti = 0 j = start_time = time.time()#select from mysql to insert mongodb by lines.for i in range(0,count,): #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 += j += continue i += j +=end_time = time.time()deltatime = end_time - start_timetotalhour = int(deltatime / )totalminute = int((deltatime - totalhour * ) / )totalsecond = int(deltatime - totalhour * - totalminute * )#print migrate data total time consuming.print "Data Migrate Finished,Total Time Consuming: %d Hour %d Minute %d Seconds" %(totalhour,totalminute,totalsecond)

*注释:按照自己的需求更改上述代码中的数据库地址,用户,密码,库名,表名以及字段名等。

四、执行迁移脚本:

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

脚本执行完成后查看/tmp/migratelog.txt数据迁移消耗的时间。

简单学习Python time模块 本文针对Pythontime模块进行分类学习,希望对大家的学习有所帮助。一.壁挂钟时间1.time()time模块的核心函数time(),它返回纪元开始的秒数,返回值为浮点

python中私有函数调用方法解密 本文实例讲述了python中私有函数调用方法。分享给大家供大家参考,具体如下:与大多数语言一样,Python也有私有的概念:①私有函数不可以从它们的

Python松散正则表达式用法分析 本文实例讲述了Python松散正则表达式用法。分享给大家供大家参考,具体如下:Python允许用户利用所谓的松散正则表达式来完成这个任务。一个松散正

标签: Python中MySQL数据迁移到MongoDB脚本的方法

本文链接地址:https://www.jiuchutong.com/biancheng/386122.html 转载请保留说明!

上一篇:python遍历目录的方法小结(python遍历文件目录)

下一篇:简单学习Python time模块(教你学python)

  • 税控盘当月不抵扣怎么申报
  • 税务登记财务负责人可以是法人吗
  • 已上传的红字发票怎么打印
  • 每个月0申报,对企业有什么影响吗?
  • 营改增后无形资产的出租和出售都属于增值税纳税范围
  • 子公司之间可以相互交易吗
  • 申报过的印花税怎么删除
  • 建筑业红字发票备注
  • 商品流通企业的资金循环
  • 企业销售矿产是否需要缴纳资源税呢?
  • 产品成本的归集和分配是什么意思
  • 小微企业分公司 企业所得税优惠
  • 企业管理与咨询机构
  • 企业如何申请定增资金
  • 电力设备维护费增值税税率
  • 如何计算房地产容积率与土地面积
  • 销售类合同审核要点
  • 发票的开具时效为
  • 个独企业如何拿钱
  • 季度不超过30万免税分录
  • 补缴社保滞纳金怎么做账
  • 税控设备 抵减
  • windows更新下载的文件在哪
  • mac文件怎么用
  • 设备维保费计算标准
  • 收到租金税费怎么计算
  • 提供给生产工人的住房的租赁费用应计入
  • linux命令df -h结果详解
  • 建筑施工企业是落实施工现场带班制度的第一责任人
  • 购买不动产会计分录
  • 期货公司向客户收取的保证金属于谁所有
  • 融资租入固定资产的入账价值
  • 解决的英文
  • 固定资产盘盈会影响所有者权益吗
  • 退款后发票如何查询
  • EarthLiveSharp中cloudinary的CDN图片缓存自动清理python脚本
  • nginx配置伪静态规则
  • vue运行报错
  • vue 父组件调用子组件效果
  • 调参数是什么意思
  • 发票作废有费用吗
  • 以非现金资产清偿债务的,债权人应当
  • 印花税账务处理会计分录
  • 网上购物没有发票怎么保修
  • 门窗安装属于土建还是安装?
  • 开基本户一定要法人身份证吗
  • access使用查询向导创建查询
  • 织梦怎么改网站主页
  • 织梦怎么建站
  • 各部门和单位按照国家有关规定收取或取得
  • 存货跌价准备借减贷增吗
  • 用发票做账是什么意思?
  • 研发支出管理的构成要素
  • 出口企业免税要交什么税
  • 短期借款利息的使用账户是
  • 企业跨年度支出怎么计算
  • 预付账款怎么做坏账
  • 什么是对公账户?
  • 银行业现金流量表
  • 仓库货架应该计入什么科目
  • 应付职工薪酬的会计科目
  • mysql安装教程5.5安装好了在哪使用
  • win2000服务器
  • win10升级win1
  • windows个性化设置在哪里
  • winxp修改ip地址方法
  • centos桌面调出命令行
  • windows 命令行 ftp
  • linux shell alias
  • win8系统笔记本怎么恢复出厂设置
  • linux服务器dns怎么设置
  • js解析机制
  • js的脚本语言
  • js class实现原理
  • jQuery 更改checkbox的状态,无效的解决方法
  • 税控盘税务数字书驱动找不到应用程序是咋回事
  • 空置房物业收费标准
  • 最新专票税率几个档
  • 买二手房土地证怎么过户
  • 长沙买房后多久可以提取公积金
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设