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

node.js將MongoDB數(shù)據(jù)同步到MySQL的步驟

 更新時(shí)間:2017年12月10日 15:20:39   作者:AlfieriChou  
這篇文章主要給大家介紹了關(guān)于node.js將MongoDB數(shù)據(jù)同步到MySQL的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧。

前言

最近由于業(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ì)腳本之家的支持。

相關(guān)文章

  • node.js中的fs.close方法使用說明

    node.js中的fs.close方法使用說明

    這篇文章主要介紹了node.js中的fs.close方法使用說明,本文介紹了fs.close方法說明、語法、接收參數(shù)、使用實(shí)例和實(shí)現(xiàn)源碼,需要的朋友可以參考下
    2014-12-12
  • 學(xué)習(xí)node.js 斷言的使用詳解

    學(xué)習(xí)node.js 斷言的使用詳解

    這篇文章主要介紹了學(xué)習(xí)node.js 斷言的使用詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • 詳解使用Typescript開發(fā)node.js項(xiàng)目(簡單的環(huán)境配置)

    詳解使用Typescript開發(fā)node.js項(xiàng)目(簡單的環(huán)境配置)

    本篇文章主要介紹了詳解使用Typescript開發(fā)node.js項(xiàng)目(簡單的環(huán)境配置),非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2017-10-10
  • PM2自動(dòng)部署代碼步驟流程總結(jié)

    PM2自動(dòng)部署代碼步驟流程總結(jié)

    這篇文章主要介紹了PM2自動(dòng)部署代碼步驟流程總結(jié),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-12-12
  • Node.js使用Angular簡單示例

    Node.js使用Angular簡單示例

    這篇文章主要介紹了Node.js使用Angular簡單示例,如何在Node.js項(xiàng)目中引入AngularJS,這次提供一個(gè)非常簡單的示例,演示AngularJS里的指令、數(shù)據(jù)綁定、服務(wù)等內(nèi)容。感興趣的小伙伴們可以參考一下
    2018-05-05
  • Node.js使用http模塊實(shí)現(xiàn)后臺(tái)服務(wù)器流程解析

    Node.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)的例子

    這篇文章主要介紹了詳解如何使用koa實(shí)現(xiàn)socket.io官網(wǎng)的例子,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-11-11
  • Node.js 實(shí)現(xiàn)簡單的無侵入式緩存框架的方法

    Node.js 實(shí)現(xiàn)簡單的無侵入式緩存框架的方法

    這篇文章主要介紹了Node.js 實(shí)現(xiàn)簡單的無侵入式緩存框架的方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-07-07
  • 使用node.JS中的url模塊解析URL信息

    使用node.JS中的url模塊解析URL信息

    本文將詳細(xì)介紹nodeJS中的URL模塊的使用方法,利用URL模塊解析出URL相關(guān)信息
    2020-02-02
  • 解決npm?install版本不匹配問題:?npm?ERR!?code?ETARGET?npm?ERR!?notarget?No?matching?version?found?for

    解決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

最新評(píng)論