溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

node.js中怎么將MongoDB數(shù)據(jù)同步到MySQL

發(fā)布時(shí)間:2021-07-16 16:42:34 來源:億速云 閱讀:223 作者:Leah 欄目:web開發(fā)

node.js中怎么將MongoDB數(shù)據(jù)同步到MySQL,很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(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:https://www.jb51.net/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
  });  
 });
 }
});

看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝您對(duì)億速云的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI