av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

mysql - node.js怎么連接數(shù)據(jù)庫(kù)

瀏覽:102日期:2022-06-17 16:12:45

問(wèn)題描述

最近在學(xué)node.js,但是不知道怎么連接數(shù)據(jù)庫(kù)。沒(méi)有文檔可以看,求推薦。怎么用node連接mysql mongoDB redis solite?求解答

問(wèn)題解答

回答1:

var mysql = require(’mysql’);var connection = mysql.createConnection({ host : ’localhost’, user : ’me’, password : ’secret’, database : ’my_db’});connection.connect();connection.query(’SELECT 1 + 1 AS solution’, function(err, rows, fields) { if (err) throw err; console.log(’The solution is: ’, rows[0].solution);});connection.end();

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

回答2:

var mongoose = require( ’mongoose’ )// Build the connection stringvar dbURI = ’mongodb://127.0.0.1/my_db’// Create the database connectionmongoose.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) })})

以上是通過(guò)mongoose連接mongodb的代碼,保存為(db.js),在主程序(假設(shè)是app.js)中引入

var express = require(’express’);var db = require(’./model/db’) var app = express();//引入一個(gè)單獨(dú)的routerapp.use(’/account’, require(’./routes/account’))

即可在其他地方(假設(shè)是上面引入的一個(gè)單獨(dú)的router account.js)使用mongoose

var express = require(’express’)var mongoose = require(’mongoose’)require(’../model/user’)let UserModel = mongoose.model('User')

數(shù)據(jù)的model需要單獨(dú)建立,比如我們建立一個(gè)model/user.js文件,以供上面的router引入使用

var mongoose = require(’mongoose’)var Schema = mongoose.Schemavar 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)

-----分割線(xiàn)--------------------------------------

redis可以用于session緩存,(當(dāng)然也可以用于暫存數(shù)據(jù)),用做緩存的話(huà)類(lèi)似以下寫(xiě)法,當(dāng)然我這里為了省事用的是mongodb臨時(shí)充當(dāng)緩存數(shù)據(jù)庫(kù)

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 secondsttl: 7 * 24 * 60 * 60 //session過(guò)期時(shí)間為7天,過(guò)期后使用cookies登陸 })}))回答3:

mysql連接可以使用庫(kù) mysqljs/mysql npm install mysqljs/mysqlmongo連接可以使用庫(kù) mongoose npm install mongooseredis連接可以使用庫(kù) redis npm install redissqlite連接可以使用庫(kù) sqlite3 npm install sqlite3

各個(gè)庫(kù)接口各不相同,請(qǐng)參考官方文檔mysql readmemongoose guideredis readmesqlite3 readme

回答4:

針對(duì)你這種的要不來(lái)幾個(gè)ORM試試??

Sequelize

Waterline

BOOKSHELF.JS

node-orm2

。。。。

根據(jù)你的需求,你需要連接的數(shù)據(jù)庫(kù)類(lèi)型,是不是需要事務(wù)支持之類(lèi)的,選擇合適的吧! 使用orm對(duì)你底層數(shù)據(jù)庫(kù)類(lèi)型的切換會(huì)友好點(diǎn)。

相關(guān)文章:
主站蜘蛛池模板: 日韩av免费看 | 正在播放国产精品 | 色偷偷人人澡人人爽人人模 | 国产精品毛片一区二区在线看 | 日本精品一区二区三区四区 | 日本不卡一区 | 一级黄色片免费 | 在线视频一区二区 | se婷婷| 黄色av一区| 天天干天天操 | 91精品一区 | 亚洲国产二区 | 国产精品精品久久久 | 国内自拍偷拍 | 欧美中文字幕一区二区三区亚洲 | 精品日韩 | 一区二区精品 | 成人妇女免费播放久久久 | 亚洲一区二区三区四区五区午夜 | 最近中文字幕第一页 | 激情亚洲 | 九九av| 一区在线播放 | 国产高清视频一区 | 国产精品国产三级国产aⅴ原创 | 日本成人三级电影 | 一级片视频免费 | 亚洲国产精品一区二区久久 | 久久精品一级 | 午夜视频在线观看一区二区 | 国产日产欧产精品精品推荐蛮挑 | 免费毛片网站在线观看 | 最新中文字幕久久 | 欧美三级久久久 | 欧美国产91 | 国产成人午夜电影网 | 免费黄色大片 | 成人在线视频免费看 | 国产精品区一区二区三 | 欧美日韩国产精品一区 |