express操作数据库

Express

集成数据库

为 Express 应用添加连接数据库的能力,只需要加载相应数据库的 Node.js 驱动即可。这里将会简要介绍如何为 Express 应用添加和使用一些常用的数据库 Node 模块。

这些数据库驱动只是其中一部分,可在 npm 官网 查找更多驱动。

Cassandra

模块cassandra-driver
安装

$ npm install cassandra-driver

示例

var cassandra = require('cassandra-driver'); var client = new cassandra.Client({ contactPoints: ['localhost']}); client.execute('select key from system.local', function(err, result) { if (err) throw err; console.log(result.rows[0]); }); 

CouchDB

模块nano
安装

$ npm install nano

示例

var nano = require('nano')('http://localhost:5984'); nano.db.create('books'); var books = nano.db.use('books'); //Insert a book document in the books database books.insert({name: 'The Art of war'}, null, function(err, body) { if (!err){ console.log(body); } }); //Get a list of all books books.list(function(err, body){ console.log(body.rows); } 

LevelDB

模块levelup
安装

$ npm install level levelup leveldown

示例

var levelup = require('levelup'); var db = levelup('./mydb'); db.put('name', 'LevelUP', function (err) { if (err) return console.log('Ooops!', err); db.get('name', function (err, value) { if (err) return console.log('Ooops!', err); console.log('name=' + value) }); }); 

MySQL

模块mysql
安装

$ npm install mysql

示例

var mysql      = require('mysql'); var connection = mysql.createConnection({ host : 'localhost', user : 'dbuser', password : 's3kreee7' }); 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(); 

MongoDB

模块mongoskin
安装

$ npm install mongoskin

示例

var db = require('mongoskin').db('localhost:27017/animals'); db.collection('mamals').find().toArray(function(err, result) { if (err) throw err; console.log(result); }); 

If you want a object model driver for MongoDB, checkout Mongoose.

Neo4j

模块apoc
安装

$ npm install apoc

示例

var apoc = require('apoc'); apoc.query('match (n) return n').exec().then( function (response) { console.log(response); }, function (fail) { console.log(fail); } ); 

PostgreSQL

模块pg
安装

$ npm install pg

示例

var pg = require('pg'); var conString = "postgres://username:password@localhost/database"; pg.connect(conString, function(err, client, done) { if (err) { return console.error('error fetching client from pool', err); } client.query('SELECT $1::int AS number', ['1'], function(err, result) { done(); if (err) { return console.error('error running query', err); } console.log(result.rows[0].number); }); }); 

Redis

模块redis
安装

$ npm install redis

示例

var client = require('redis').createClient(); client.on('error', function (err) { console.log('Error ' + err); }); client.set('string key', 'string val', redis.print); client.hset('hash key', 'hashtest 1', 'some value', redis.print); client.hset(['hash key', 'hashtest 2', 'some other value'], redis.print); client.hkeys('hash key', function (err, replies) { console.log(replies.length + ' replies:'); replies.forEach(function (reply, i) { console.log(' ' + i + ': ' + reply); }); client.quit(); }); 

SQLite

模块sqlite3
安装

$ npm install sqlite3

示例

var sqlite3 = require('sqlite3').verbose(); var db = new sqlite3.Database(':memory:'); db.serialize(function() { db.run('CREATE TABLE lorem (info TEXT)'); var stmt = db.prepare('INSERT INTO lorem VALUES (?)'); for (var i = 0; i < 10; i++) { stmt.run('Ipsum ' + i); } stmt.finalize(); db.each('SELECT rowid AS id, info FROM lorem', function(err, row) { console.log(row.id + ': ' + row.info); }); }); db.close(); 

ElasticSearch

模块elasticsearch
安装

$ npm install elasticsearch

示例

var elasticsearch = require('elasticsearch'); var client = elasticsearch.Client({ host: 'localhost:9200' }); client.search({ index: 'books', type: 'book', body: { query: { multi_match: { query: 'express js', fields: ['title', 'description'] } } } }).then(function(response) { var hits = response.hits.hits; }, function(error) { console.trace(error.message); }); 

冀ICP备15008021号|© Express 中文网 2015

转载于:https://www.cnblogs.com/leigepython/p/9244767.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值