mysql - node.js怎么连接数据库
ringa_lee
ringa_lee 2017-04-17 15:46:49
0
4
635

最近在学node.js,但是不知道怎么连接数据库。没有文档可以看,求推荐。怎么用node连接mysql mongoDB redis solite?求解答

ringa_lee
ringa_lee

ringa_lee

全部回覆(4)
左手右手慢动作

雷雷


https://github.com/mysqljs/my...

Ty80
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/mysql
mongo连接可以使用库 mongoose npm install mongoose
redis连接可以使用库 redis npm install redis
sqlite连接可以使用库 sqlite3 npm install sqlite3

各個函式庫介面各不相同,請參考官方文件
mysql readme
mongoose guide
redis readme
sqlite3 readme

PHPzhong

針對你這種的要不來幾個ORM試試? ?

  • Sequelize

  • Waterline

  • BOOKSHELF.JS

  • node-orm2

  • 。 。 。 。

根據你的需求,你需要連結的資料庫類型,是不是需要事務支援之類的,選擇合適的吧! 使用orm對你底層資料庫類型的切換會友善一點。

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板