久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術文章
文章詳情頁

mysql - node.js怎么連接數據庫

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

問題描述

最近在學node.js,但是不知道怎么連接數據庫。沒有文檔可以看,求推薦。怎么用node連接mysql mongoDB redis solite?求解答

問題解答

回答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) })})

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

var express = require(’express’);var db = require(’./model/db’) var app = express();//引入一個單獨的routerapp.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.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)

-----分割線--------------------------------------

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

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

各個庫接口各不相同,請參考官方文檔mysql readmemongoose guideredis readmesqlite3 readme

回答4:

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

Sequelize

Waterline

BOOKSHELF.JS

node-orm2

。。。。

根據你的需求,你需要連接的數據庫類型,是不是需要事務支持之類的,選擇合適的吧! 使用orm對你底層數據庫類型的切換會友好點。

相關文章:
主站蜘蛛池模板: 达拉特旗| 鲁甸县| 拜泉县| 德兴市| 卫辉市| 湖州市| 阳曲县| 奎屯市| 弥勒县| 舞钢市| 张家口市| 溧水县| 三穗县| 泉州市| 嘉黎县| 清水河县| 酒泉市| 克东县| 延津县| 济南市| 重庆市| 平原县| 望城县| 长葛市| 丰顺县| 龙川县| 濮阳县| 漯河市| 达拉特旗| 霞浦县| 哈尔滨市| 龙井市| 滦平县| 南投县| 常德市| 泽州县| 康定县| 崇明县| 汉寿县| 资讯 | 营山县|