这部分示例将示范SQLite3MongoDB这两种不同类型的数据库在 Node.js 中的使用方法。首先,我们要在code目录下执行mkdir 06_database命令来创建用于存放这一组示例的目录。

1. SQLite

SQLite3是一个轻量级的关系型数据库,我们在这里用它来示范 Node.js 对关系型数据库的处理。首先,在code/06_database目录下执行mkdir sqlite命令,并执行以下步骤:

  1. code/06_database/sqlite目录下执行npm install sqlite3命令,将sqlite3安装到当前示例项目中。

  2. 为控制程序按串行方式执行,需在code/06_database/sqlite目录下执行npm install async命令,将async包安装到当前示例项目中。

  3. 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
  4. 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()
    }
    ])
  5. 保存所有文件后,在code/06_database/sqlite目录下执行node useSqlite.js命令,结果如下:

2. MongoDB

MongoDB是非关系型数据库的一个典型代表,我们在这里用它来示范 Node.js 对关系型数据库的处理。在 Node.js 中操作MongoDB数据库有两个扩展包可以选择,下面我们一一来演示。首先,在code/06_database目录下执行mkdir mongodb命令,并执行以下步骤:

使用mongodb
  1. code/06_database/mongodb目录下执行npm install mongodb命令,将mongodb包安装到当前示例项目中。

  2. 为控制程序按串行方式执行,需在code/06_database/mongodb目录下执行npm install async命令,将async包安装到当前示例项目中。

  3. 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()
    })
  4. 保存所有文件后,在code/06_database/mongodb目录下执行node useMongodb.js命令,结果如下:

使用mongoose
  1. code/06_database/mongodb目录下执行npm install mongoose命令,将mongoose包安装到当前示例项目中。

  2. 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)
    })
    })
  3. 保存所有文件后,在code/06_database/mongodb目录下执行node useMongoose.js命令,结果如下:

Node.js 学习笔记之四:使用数据库的更多相关文章

  1. 一点感悟:《Node.js学习笔记》star数突破1000+

    写作背景 笔者前年开始撰写的<Node.js学习笔记> github star 数突破了1000,算是个里程碑吧. 从第一次提交(2016.11.03)到现在,1年半过去了.突然有些感慨, ...

  2. Node.js学习笔记(3):NPM简明教程

    Node.js学习笔记(3):NPM简明教程 NPM常用操作 更新NPM版本 npm install npm -g -g,表示全局安装.我们可以指定更新版本,只需要在后面填上@版本号即可,也可以输入@ ...

  3. 系列文章--Node.js学习笔记系列

    Node.js学习笔记系列总索引 Nodejs学习笔记(一)--- 简介及安装Node.js开发环境 Nodejs学习笔记(二)--- 事件模块 Nodejs学习笔记(三)--- 模块 Nodejs学 ...

  4. Node.js学习笔记(2):基本模块

    Node.js学习笔记(2):基本模块 模块 引入模块 为了编写可维护的代码,我们把很多函数分组,分别放到不同的文件里,这样,每个文件包含的代码就相对较少,很多编程语言都采用这种组织代码的方式.在No ...

  5. Node.js学习笔记(1):Node.js快速开始

    Node.js学习笔记(1):Node.js快速开始 Node.js的安装 下载 官方网址:https://nodejs.org/en/ 说明: 在Windows上安装时务必选择全部组件,包括勾选Ad ...

  6. Node.js学习笔记(4):Yarn简明教程

    Node.js学习笔记(4):Yarn简明教程. 引入Yarn NPM是常用的包管理工具,现在我们引入是新一代的包管理工具Yarn.其具有快速.安全.可靠的特点. 安装方式 使用npm工具安装yarn ...

  7. Node.js学习笔记(一):快速开始

    最近接了一个node项目,虽然最后顺利完成了,但是由于第一次实战,整个过程是赶出来的,许多地方一知半解.现在项目结束了,就静下心来系统地学一学,理一理,读书不忘拿笔,既然读书了,当然就要记点东西.一方 ...

  8. Node.js学习笔记(3)——关于回调函数和函数的回调

    说明:本人是node.js的初学者,尝试向别人解释这是怎么回事是自我学习的一个好方法.如果你发现有些地方并不是那么正确,欢迎提出来让我知道以便修正,共同进步,谢过^_^.       欢迎交流,本人微 ...

  9. Node.js学习笔记——Node.js开发Web后台服务

    一.简介 Node.js 是一个基于Google Chrome V8 引擎的 JavaScript 运行环境.Node.js 使用了一个事件驱动.非阻塞式 I/O 的模型,使其轻量又高效.Node.j ...

随机推荐

  1. python之路第一节-pip的使用

    第一次写博客,一边吃着旺仔冻痴一边学着python,爽~ 我之理解pip 首先,python封装好了大量的函数,这些函数存在各种各样的库中. 那么怎么去向我们可爱的pycharm等软件导入这些库呢,两 ...

  2. 【HDU5869】 Different GCD Subarray Query 题解 (线段树维护区间GCD)

    题目大意:求区间$[L,R]$中所有子区间产生的最大公因数的个数. ------------------------- 对于$gcd$,我们知道$gcd(a,b,c)=gcd(gcd(a,b),c)$ ...

  3. 蓝奏云数值验证码识别,python调用虹鱼图灵识别插件,超高正确率

    识别验证码一直是本人想要做的事情,一直在接触按键精灵,了解到有一个虹鱼图灵识别插件专门做验证码和图像识别,原理就是图片处理和制作字库识别,制作字库我一直觉得很麻烦,工程量太大.不管怎样,它能用能达到我 ...

  4. SpringCloud微服务:基于Nacos组件,整合Dubbo框架

    源码地址:GitHub·点这里 || GitEE·点这里 一.基础组件简介 1.Dubbo框架 Dubbo服务化治理的核心框架,之前几年在国内被广泛使用,后续由于微服务的架构的崛起,更多的公司转向微服 ...

  5. 8、Builder 建造者模式 组装复杂的实例 创造型模式

    1.什么是Builder模式 定义: 将一个复杂对象的构建与表示相分离,使得同样的构建过程可以创建不同的表示.大白话就是,你不需要知道这个类的内部是什么样的,只用把想使用的参数传进去就可以了,达到了解 ...

  6. RF,SVM和NN的优缺点

    1. 随机森林优缺点 随机森林(RF)是Bagging的一个扩展变体.RF在以决策树为基分类器进行集成的基础上,进一步在决策树的训练过程中引入了随机属性选择. Bagging就是对数据集训练多个基分类 ...

  7. C#LeetCode刷题-分治算法

    分治算法篇 # 题名 刷题 通过率 难度 4 两个排序数组的中位数 C#LeetCode刷题之#4-两个排序数组的中位数(Median of Two Sorted Arrays)-该题未达最优解 30 ...

  8. C#LeetCode刷题之#344-反转字符串​​​​​​​(Reverse String)

    问题 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/3933 访问. 编写一个函数,其作用是将输入的字符串反转过来. 输 ...

  9. Windows下,配置VS Code的Java开发环境

    Windows下,配置VS Code的Java开发环境 前言 最近痴迷于VS Code的开发环境配置,原因就在于它的轻巧和免费,还能当一个非常棒的文本编辑器.如果之前你配置过VS Code并且失败了, ...

  10. CF 1383B GameGame

    传送门 题目:给定长度为n的数组a,A和B轮流拿走一个数,开始时A和B拥有的v为0,A和B每次拿走一个数时,他的v = v^ ai,A和B都很聪明,问都按照最优的情况考虑,拿完所有数之后A和B的v的大 ...