最近在学node.js,但是不知道怎么连接数据库。没有文档可以看,求推荐。怎么用node连接mysql mongoDB redis solite?求解答
ringa_lee
雷雷
https://github.com/mysqljs/my...
var mongoose = require( 'mongoose' ) // Build the connection string var dbURI = 'mongodb://127.0.0.1/my_db' // Create the database connection mongoose.connect(dbURI); mongoose.connection.on('connected', function () { console.log('Mongoose connected to ' + dbURI); }) mongoose.connection.on('error',function (err) { console.log('Mongoose connection error: ' + err) }) mongoose.connection.on('disconnected', function () { console.log('Mongoose disconnected') }) process.on('SIGINT', function() { mongoose.connection.close(function () { console.log('Mongoose disconnected through app termination') process.exit(0) }) })
以上是透過mongoose連接mongodb的程式碼,儲存為(db.js),在主程式(假設是app.js)中引入
var express = require('express'); var db = require('./model/db') var app = express(); //引入一个单独的router app.use('/account', require('./routes/account'))
即可在其他地方(假設是上面引入的一個單獨的router account.js)使用mongoose
var express = require('express') var mongoose = require('mongoose') require('../model/user') let UserModel = mongoose.model("User")
資料的model需要單獨建立,例如我們建立一個model/user.js文件,以便上面的router引入使用
var mongoose = require('mongoose') var Schema = mongoose.Schema var userSchema = new Schema({ email:{type:String, index:true, unique:true}, unm:{type:String,index:true, unique:true}, password:String, role:{type:String, enum: ["student","controller","gm"], index:true}, lang:[String], regTime:Number, year:String, month:String, day:String, }) mongoose.model('User',userSchema)
-----分割線--------------------------------------
redis可以用於session緩存,(當然也可以用於暫存資料),用做緩存的話類似以下寫法,當然我這裡為了省事用的是mongodb臨時充當緩存數據庫
var MongoStore = require('connect-mongo')(session) app.use(session({ secret: ['secret1', 'secret2'], saveUninitialized: false, // don't create session until something stored resave: false, //don't save session if unmodified store: new MongoStore({ url: 'mongodb://localhost/my_db', touchAfter: 24 * 3600, // time period in seconds ttl: 7 * 24 * 60 * 60 //session过期时间为7天,过期后使用cookies登陆 }) }))
mysql連線可以使用函式庫 mysqljs/mysql npm install mysqljs/mysqlmongo连接可以使用库 mongoose npm install mongooseredis连接可以使用库 redis npm install redissqlite连接可以使用库 sqlite3 npm install sqlite3
npm install mysqljs/mysql
npm install mongoose
npm install redis
npm install sqlite3
各個函式庫介面各不相同,請參考官方文件mysql readmemongoose guideredis readmesqlite3 readme
針對你這種的要不來幾個ORM試試? ?
Sequelize
Waterline
BOOKSHELF.JS
node-orm2
。 。 。 。
根據你的需求,你需要連結的資料庫類型,是不是需要事務支援之類的,選擇合適的吧! 使用orm對你底層資料庫類型的切換會友善一點。
雷雷
https://github.com/mysqljs/my...
以上是透過mongoose連接mongodb的程式碼,儲存為(db.js),在主程式(假設是app.js)中引入
即可在其他地方(假設是上面引入的一個單獨的router account.js)使用mongoose
資料的model需要單獨建立,例如我們建立一個model/user.js文件,以便上面的router引入使用
-----分割線--------------------------------------
redis可以用於session緩存,(當然也可以用於暫存資料),用做緩存的話類似以下寫法,當然我這裡為了省事用的是mongodb臨時充當緩存數據庫
mysql連線可以使用函式庫 mysqljs/mysql
npm install mysqljs/mysql
mongo连接可以使用库 mongoose
npm install mongoose
redis连接可以使用库 redis
npm install redis
sqlite连接可以使用库 sqlite3
npm install sqlite3
各個函式庫介面各不相同,請參考官方文件
mysql readme
mongoose guide
redis readme
sqlite3 readme
針對你這種的要不來幾個ORM試試? ?
Sequelize
Waterline
BOOKSHELF.JS
node-orm2
。 。 。 。
根據你的需求,你需要連結的資料庫類型,是不是需要事務支援之類的,選擇合適的吧! 使用orm對你底層資料庫類型的切換會友善一點。