这部分示例将示范SQLite3
、MongoDB
这两种不同类型的数据库在 Node.js 中的使用方法。首先,我们要在code
目录下执行mkdir 06_database
命令来创建用于存放这一组示例的目录。
1. SQLite
SQLite3
是一个轻量级的关系型数据库,我们在这里用它来示范 Node.js 对关系型数据库的处理。首先,在code/06_database
目录下执行mkdir sqlite
命令,并执行以下步骤:
-
在
code/06_database/sqlite
目录下执行npm install sqlite3
命令,将sqlite3
安装到当前示例项目中。 -
为控制程序按串行方式执行,需在
code/06_database/sqlite
目录下执行npm install async
命令,将async
包安装到当前示例项目中。 -
在
code/06_database/sqlite
目录下执行touch Sqlite.js
,创建一个脚本文件,具体如下:const fs = require('fs') const sqlite3 = require('sqlite3').verbose() class SqliteDB { constructor(file) { this.db = new sqlite3.Database(file) const db_exist = fs.existsSync(file) if ( !db_exist ) { console.error('数据库文件创建成功!') fs.openSync(file, 'w') } } createTable(sql) { this.db.serialize(function() { this.run(sql, function(err) { if( err !== null ) { return console.error('错误信息:' + err.message) } }) }) } insertData(sql, objects) { this.db.serialize(function() { const stmt = this.prepare(sql) for ( let i = 0; i < objects.length; ++i ) { stmt.run(objects[i]) } stmt.finalize() }) } queryData(sql, callback, message) { this.db.all(sql, function(err, rows) { if( err !== null ) { return console.error('错误信息:' + err.message) } if( callback ) { callback(rows, message) } }) } executeSql(sql) { this.db.run(sql, function(err) { if( err !== null ) { return console.error('错误信息:' + err.message) } }) } close() { this.db.close() } } module.exports = SqliteDB
-
在
code/06_database/sqlite
目录下执行touch useSqlite.js
,创建一个脚本文件,具体如下:const async = require('async') const SqliteDB = require('./Sqlite') const file = "HRDB.db" const sqliteDB = new SqliteDB(file) function dataDeal(objects, message) { console.log(message) for ( const i = 0; i < objects.length; ++i ) { console.log(objects[i]) } } async.waterfall([ function (callback) { // 创建表格 const createTableSql = ` create table if not exists HR_TABLE ( name TEXT, age TEXT, sex TEXT, items TEXT );` sqliteDB.createTable(createTableSql) callback() }, function (callback) { // 插入数据 const insertTileSql = ` insert into HR_TABLE (name, age, sex, items) values(?, ?, ?, ?)` const arr = [ ['凌杰', '24', '男', '看书, 看电影, 旅游'], ['蔓儿', '25', '女', '看书, 看电影, 写作'], ['张语', '32', '女', '看书, 旅游, 绘画'] ] sqliteDB.insertData(insertTileSql, arr) callback() }, function (callback) { // 查询数据 const querySql = 'select * from HR_TABLE' sqliteDB.queryData(querySql, dataDeal, '初始数据') callback() }, function (callback) { // 更新数据 const updateSql = `update HR_TABLE set age = 37 where name = "凌杰"` sqliteDB.executeSql(updateSql) callback() }, function (callback) { // 查询更新后的数据 querySql = `select * from HR_TABLE` sqliteDB.queryData(querySql, dataDeal, '更新后数据') callback() }, function (callback) { sqliteDB.close() callback() } ])
-
保存所有文件后,在
code/06_database/sqlite
目录下执行node useSqlite.js
命令,结果如下:
2. MongoDB
MongoDB
是非关系型数据库的一个典型代表,我们在这里用它来示范 Node.js 对关系型数据库的处理。在 Node.js 中操作MongoDB
数据库有两个扩展包可以选择,下面我们一一来演示。首先,在code/06_database
目录下执行mkdir mongodb
命令,并执行以下步骤:
使用mongodb
包
-
在
code/06_database/mongodb
目录下执行npm install mongodb
命令,将mongodb
包安装到当前示例项目中。 -
为控制程序按串行方式执行,需在
code/06_database/mongodb
目录下执行npm install async
命令,将async
包安装到当前示例项目中。 -
在
code/06_database/mongodb
目录下执行touch useMongodb.js
,创建一个脚本文件,具体如下:const MongoClient = require('mongodb').MongoClient const async = require('async') const server = 'mongodb://localhost:27017' const dbName = 'hrdb' const collName = 'hr_table' const dbPath = server + '/' + dbName MongoClient.connect(dbPath, { useNewUrlParser: true }, function(err, db) { if ( err !== null ) { return console.error('错误信息:' + err.message) } const dbo = db.db(dbName) console.log(dbName + '数据库创建成功') const collect = dbo.collection(collName) console.log(collName + '集合创建成功') async.series([ // 控制程序串行执行 function (callback) { // 插入单条数据 const data = { name : '杨过', age : '42', sex : '男', items : '看书, 喝酒, 习武' } collect.insertOne(data, function(err, res) { if ( err !== null ) { return console.error('错误信息:' + err.message) } console.log('单条数据插入成功') }) callback() }, function (callback) { // 插入多条数据 const dataArray = [ { name : '小龙女', age : '24', sex : '男', items : '看书, 唱歌, 习武' }, { name : '郭靖', age : '52', sex : '男', items : '看书, 喝酒, 习武' }, { name : '黄蓉', age : '45', sex : '女', items : '看书, 绘画, 习武' }, { name : '雅典娜', age : '24', sex : '女', items : '看书, 音乐, 被救' } ] collect.insertMany(dataArray, function(err, res) { if ( err !== null ) { return console.error('错误信息:' + err.message) } console.log('数组插入成功') }) callback() }, function (callback) { // 列出所有数据 collect. find({}).toArray(function(err, result) { if ( err !== null ) { return console.error('错误信息:' + err.message) } console.log('列出当前集合中的所有数据:') console.log(result) }) callback() }, function (callback) { // 更新单一数据 const whereData = {'name' : '小龙女'} const updataValue = { $set: { 'sex' : '女' } } collect.updateOne(whereData, updataValue, function(err, res) { if ( err !== null ) { return console.error('错误信息:' + err.message) } console.log(whereData['name'] + "的数据更新成功") }) callback() }, function (callback) { // 查询指定数据 const querystr = { 'name' : '小龙女' } collect. find(querystr).toArray(function(err, result) { if ( err !== null ) { return console.error('错误信息:' + err.message) } console.log('查看更新后的' + querystr['name'] + '的数据:') console.log(result) }) callback() }, function (callback) { // 删除指定单一数据 const whereData = { 'name' : '黄蓉' } collect.deleteOne(whereData,function(err, result) { if ( err !== null ) { return console.error('错误信息:' + err.message) } console.log(whereData['name'] + '的数据已被删除') }) callback() }, function (callback) { // 查询所有数据,并按name降序排列 const isort = { name : -1 } collect. find({}).sort(isort).toArray(function(err, result) { if ( err !== null ) { return console.error('错误信息:' + err.message) } console.log('降序排列当前集合中的所有数据:') console.log(result) }) callback() }, function (callback) { // 删除指定多条数据 const whereData = { 'age' : '24' } collect.deleteMany(whereData,function(err, result) { if ( err !== null ) { return console.error('错误信息:' + err.message) } console.log('年龄为' + whereData['age'] + '的数据已被删除') }) callback() }, function (callback) { // 查询所有数据,并按name升序排列 const isort = { name : 1 } collect. find({}).sort(isort).toArray(function(err, result) { if ( err !== null ) { return console.error('错误信息:' + err.message) } console.log('升序排列当前集合中的所有数据:') console.log(result) }) callback() }, function (callback) { // 删除指定集合 dbo.dropCollection(collName, function(err, delOK) { if ( err !== null ) { return console.error('错误信息:' + err.message) } if ( delOK !== null ) { console.log(collName + "集合已删除!") } }) callback() } ]) db.close() })
-
保存所有文件后,在
code/06_database/mongodb
目录下执行node useMongodb.js
命令,结果如下:
使用mongoose
包
-
在
code/06_database/mongodb
目录下执行npm install mongoose
命令,将mongoose
包安装到当前示例项目中。 -
在
code/06_database/mongodb
目录下执行touch useMongoose.js
,创建一个脚本文件,具体如下:const server = 'mongodb://localhost:27017' const dbName = 'hrdb' const collName = 'hr_table' const dbPath = server + '/' + dbName const mongoose = require('mongoose'); const async = require('async') const Schema = mongoose.Schema const hrSchema = new Schema({ name : { type : String, required: true }, age : { type : String, required: true }, sex : { type : String, required: true }, items : { type : String, required: true } }) const hrModel = new mongoose.model('Hrobj', hrSchema) mongoose.connect(dbPath, {useNewUrlParser: true}); const conn = mongoose.connection conn.on('error', console.error.bind(console, '连接错误:')) conn.on('open', console.log.bind(console, '数据库连接成功')) conn.on('disconnected', console.log.bind(console, '断开数据库连接')) conn.once('open', function(){ async.series([ function(callback) { // 插入单条数据 const someone = new hrModel ({ name : '杨过', age : '42', sex : '男', items : '看书, 喝酒, 习武' }) someone.save(function(err, one){ callback(err, one.name+'的数据插入成功') }) }, function(callback) { hrModel.find(function(err, hrTable){ callback(err, '插入一条数据后的结果:' + hrTable) }) }, function(callback) { // 插入多条数据 const dataArray = [ { name : '小龙女', age : '24', sex : '男', items : '看书, 唱歌, 习武' }, { name : '郭靖', age : '52', sex : '男', items : '看书, 喝酒, 习武' }, { name : '黄蓉', age : '45', sex : '女', items : '看书, 绘画, 习武' }, { name : '雅典娜', age : '24', sex : '女', items : '看书, 音乐, 被救' }, { name : '阿波罗', age : '24', sex : '女', items : '看书, 音乐, 被救' } ] hrModel.insertMany(dataArray, function(err) { callback(err, '数组中的数据插入成功') }) }, function(callback) { hrModel.find(function(err, hrTable){ callback(err, '插入多条数据后的结果:' + hrTable) }) }, function(callback) { hrModel.updateMany({sex:'男'}, {sex:'女'}, function(err, one){ callback(err, '将所有男人改为女人') }) }, function(callback) { hrModel.updateOne({name:'阿波罗'}, {sex:'男'}, function(err, one){ callback(err, '将阿波罗的性别改为:男') }) }, function(callback) { hrModel.find({age:'24'}, function(err, hrTable){ callback(err, '所有年龄为24的数据:' + hrTable) }) }, function(callback) { hrModel.findOne({age:'24'}, function(err, hrTable){ callback(err, '第一个年龄为24的结果:' + hrTable) }) }, function(callback) { hrModel.deleteMany({age:'24'}, function(err, hrTable){ callback(err, '所有年龄为24数据已被删除') }) }, function(callback) { hrModel.find({age:'24'}, function(err, hrTable){ callback(err, '所有年龄为24的数据:' + hrTable) }) }, function(callback) { hrModel.deleteMany({}, function(err, hrTable){ callback(err, '所有数据已被删除') }) }, function(callback) { hrModel.find(function(err, hrTable){ callback(err, '删除所有数据后的结果:' + hrTable) }) }, function(callback) { mongoose.disconnect(function(err){ callback(err, '正在断开连接……') }) } ], function(err, message) { if ( err !== null ) { return console.error('错误信息:' + err.message) } console.log(message) }) })
-
保存所有文件后,在
code/06_database/mongodb
目录下执行node useMongoose.js
命令,结果如下: