node.js將MongoDB數(shù)據(jù)同步到MySQL的步驟
前言
最近由于業(yè)務(wù)需要,APP端后臺(tái)需要將MongoDB中的數(shù)據(jù)同步到Java端后臺(tái)的MySQL中,然后又將MySQL中算好的數(shù)據(jù),同步到MongoDB數(shù)據(jù)庫。
這個(gè)過程看是很繁瑣,實(shí)際上這就是一個(gè)互相寫表的過程。
接下來就看看node.js將MongoDB中的數(shù)據(jù)批量插入到MySQL數(shù)據(jù)庫的實(shí)現(xiàn)過程。話不多說了,來一起看看詳細(xì)的介紹吧。
環(huán)境
- node.js
- MongoDB
- MySQL
- npm
需要的模塊
- mongoose
- MySQL
準(zhǔn)備好MongoDB中的數(shù)據(jù)
- 比如說:我這里要同步的是用戶表,用戶表中包含username,email,password...
- 通過MongoDB shell命令插入1000條數(shù)據(jù)
實(shí)現(xiàn)
mongoose的Schema我這里就不寫了,大家可以上網(wǎng)進(jìn)行查看,node.js連接MongoDB和MySQL的pool看下面:
node.js連接MongoDB:http://www.dbjr.com.cn/article/98813.htm
Nodejs mysql pool使用實(shí)例:
mysql模塊為felixge/node-mysql
源碼如下:
/** * Created by kevalin on 2015/4/22. */ var express = require('express'); var router = express.Router(); var mysql = require('mysql'); var conf = require('../config/dbconnection'); //定義pool池 var pool = mysql.createPool( { host : conf.dbMysql.host, user : conf.dbMysql.user, password : conf.dbMysql.password, database : conf.dbMysql.database, port : conf.dbMysql.port } ); router.get('/', function(req, res) { var selectSites = "select *, date_format(do_time, '%Y-%m-%d %H:%i:%s') as time from siteinfo order by id"; pool.getConnection(function(err, connection) { if (err) throw err; connection.query(selectSites, function(err, rows) { if (err) throw err; res.render('sites', {title : '站點(diǎn)分布', results : rows}); //回收pool connection.release(); }); }); }); module.exports = router;
下面上關(guān)鍵代碼
思路:
先從MongoDB查詢數(shù)據(jù)然后通過遍歷插入MySQL中。
User.find({}, (err, user) => { if (err) res.send(err); for( let i = 0 ; i < family.length ; i ++ ) { console.log("第" + (i + 1) + "條數(shù)據(jù)"); let username = user[i].username; let email = user[i].email; let password = user[i].password; let sql = "insert into user_table(username, email, password) values ('" + username + "','" + email + "','" + password + "');"; pool.query(sql,(err, rows) => { if (err) res.send(err); res.json({ message:'數(shù)據(jù)插入成功', rows }); }); } });
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
- Python實(shí)現(xiàn)將數(shù)據(jù)框數(shù)據(jù)寫入mongodb及mysql數(shù)據(jù)庫的方法
- 記一次MongoDB性能問題(從MySQL遷移到MongoDB)
- Python中MySQL數(shù)據(jù)遷移到MongoDB腳本的方法
- MongoDB與MySQL的操作對(duì)比表及區(qū)別介紹
- MongoDB與MySQL常用操作語句對(duì)照
- MongoDB系列教程(五):mongo語法和mysql語法對(duì)比學(xué)習(xí)
- python連接MySQL、MongoDB、Redis、memcache等數(shù)據(jù)庫的方法
- mongodb與mysql命令詳細(xì)對(duì)比
- 基于MySQL到MongoDB簡易對(duì)照表的詳解
- MySQL和MongoDB設(shè)計(jì)實(shí)例對(duì)比分析
- 分析MongoDB和MySQL各自的關(guān)鍵特性、差別和優(yōu)勢(shì)
相關(guān)文章
詳解使用Typescript開發(fā)node.js項(xiàng)目(簡單的環(huán)境配置)
本篇文章主要介紹了詳解使用Typescript開發(fā)node.js項(xiàng)目(簡單的環(huán)境配置),非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-10-10Node.js使用http模塊實(shí)現(xiàn)后臺(tái)服務(wù)器流程解析
這篇文章將會(huì)教會(huì)你前端工程師怎么搭建后臺(tái)服務(wù)器,做自己的后端開發(fā),同時(shí),在這篇文章開始你就開始正式進(jìn)入全棧的道路咯!本片文章將細(xì)解http模塊,在開始前我們將復(fù)習(xí)一點(diǎn)計(jì)算機(jī)網(wǎng)絡(luò)的知識(shí)2022-09-09詳解如何使用koa實(shí)現(xiàn)socket.io官網(wǎng)的例子
這篇文章主要介紹了詳解如何使用koa實(shí)現(xiàn)socket.io官網(wǎng)的例子,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-11-11Node.js 實(shí)現(xiàn)簡單的無侵入式緩存框架的方法
這篇文章主要介紹了Node.js 實(shí)現(xiàn)簡單的無侵入式緩存框架的方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-07-07解決npm?install版本不匹配問題:?npm?ERR!?code?ETARGET?npm?ERR!?
這篇文章主要介紹了如何解決npm?install版本不匹配問題:?npm?ERR!?code?ETARGET?npm?ERR!?notarget?No?matching?version?found?for,文中給出了詳細(xì)的解決方法,需要的朋友可以參考下2024-02-02