MongoDB学习之mongoose

MongoDB介绍:

MongoDB是基于Javascript语言的数据库,存储格式是JSON,而Node也是基于JavaScript的环境(库),所以node和mongoDB的搭配能减少因为数据转换带来的时间空间开销。

Mongoose介绍:

是MongoDB的一个对象模型工具,它将数据库中的数据转换为JavaScript对象以供你在应用中使用,封装了MongoDB对文档的的一些增删改查等常用方法,

让NodeJS操作Mongodb数据库变得更加灵活简单。

预备:

一定要先开启mongodb服务,进入mongodb\bin\,执行mongod --dbpath d:\data

d:\data是存储数据的地方,通常位于mongodb安装的根目录下。

第一步,在项目里安装mongoose,并引入

// 安装

cnpm install mongoose --save

// 引入

const mongoose = require(‘mongoose‘);

第二步,连接数据库

// 连接本地的数据库

let db = mongoose.createConnection(‘mongodb://localhost/testmongoose‘);

接着:

// 设置数据类型

let monSchema = new mongoose.Schema({
    name: {
        type: String,
        default: ‘username‘
    },
    age: {
        type: Number
    },
    gender: {
        type: String,
        default: ‘女‘
    }
});

// 选择集合

let MonModel = db.model(‘user‘, monSchema);

// 模拟一个数据集

let content = {name: ‘nick‘, age: 23, gender: ‘男‘};

// 实例化对象并插入数据

let monInsert = new MonModel(content);

// 保存并关闭连接

monInsert.save((err) => {
    if(err) {
        console.log(err);
    } else {
        console.log(‘成功插入数据‘);
    }
    // 关闭数据库
    db.close();
});

执行这个node文件,插入数据成功!

叮叮~~数据库里面有数据啦!

mongo.js完整代码:

// 引入模块
const mongoose = require(‘mongoose‘);
// 连接数据库
let db = mongoose.createConnection(‘mongodb://localhost/testmongoose‘);
// 设置数据类型
let monSchema = new mongoose.Schema({
    name: {
        type: String,
        default: ‘username‘
    },
    age: {
        type: Number
    },
    gender: {
        type: String,
        default: ‘女‘
    }
});
// 选择集合
let MonModel = db.model(‘user‘, monSchema);
// 数据集
let content = {name: ‘Nick‘, age: 23, gender: ‘男‘};
// 实例化对象并插入数据
let monInsert = new MonModel(content);
monInsert.save((err) => {
    if(err) {
        console.log(err);
    } else {
        console.log(‘成功插入数据‘);
    }
    // 关闭数据库
    db.close();
});

增删改查完整代码:

// 引入模块
const mongoose = require(‘mongoose‘);
// 连接数据库
let db = mongoose.createConnection(‘mongodb://localhost/testmongoose‘);
// 设置数据类型
let monSchema = new mongoose.Schema({
    name: {
        type: String,
        default: ‘username‘
    },
    age: {
        type: Number
    },
    gender: {
        type: String,
        default: ‘女‘
    }
});
// 选择集合
let MonModel = db.model(‘user‘, monSchema);

// 插入数据
function insertData () {
    // 数据集
    let content = {name: ‘Nick‘, age: 23, gender: ‘男‘};
    // 实例化对象并插入数据
    let monInsert = new MonModel(content);
    monInsert.save((err) => {
        if(err) {
            console.log(err);
        } else {
            console.log(‘成功插入数据‘);
        }
        // 关闭数据库
        db.close();
    });
}

// 删除数据
function deleteData () {
    // 要删除的条件
    let del = {name: ‘Nick‘};
    MonModel.remove(del, (err, result) => {
        if(err) {
            console.log(err);
        } else {
            console.log(‘delete: ‘ + result);
        }
        // 关闭数据库
        db.close();
    });
}

// 修改数据
function updateData() {
    // 原数据字段值
    let oldValue = {name: ‘Nick‘};
    // 单条件更新
    let newData1 = {$set: {name: ‘风夏‘}};
    // 多条件更新
    let newData2 = {$set: {name: ‘风夏‘, gender: ‘女‘}};
    MonModel.update(oldValue, newData2, (err, result) => {
        if(err) {
            console.log(err);
        } else {
            console.log(‘update‘);
        }
        // 关闭数据库
        db.close();
    });
}

// 查询数据
function findData() {
    // 要查询的字段
    let content = {name: ‘风夏‘};
    let field = {name: 1, age:1, gender:1};
    MonModel.find(content, field, (err, result) => {
        if(err) {
            console.log(err);
        } else {
            console.log(result);
        }
    });
}

//insertData();
//deleteData();
//updateData();
findData();
时间: 2024-10-22 00:28:47

MongoDB学习之mongoose的相关文章

MongoDB学习总结(二)

前言:学习札记! MongoDB学习总结(二) 1.  安装.初识 之前写过一篇MongoDB的快速上手文章,里边详细的讲了如何安装.启动MongoDB,这里就不再累述安装过程,简单介绍一下Mongodb的基本操作. 打开命令行窗口,输入“mongo”命令,默认会连接到test数据库. l  Insert db.person.insert({"name":"Olive","age":18}) db.person.insert({"nam

MongoDB学习笔记系列

回到占占推荐博客索引 该来的总会来的,Ef,Redis,MVC甚至Sqlserver都有了自己的系列,MongoDB没有理由不去整理一下,这个系列都是平时在项目开发时总结出来的,希望可以为各位一些帮助和启发,文章中有对新技术的研究(Mongo驱动),对老技术的回顾(代码重构),还有对架构设计的阐述等(面向接口编程,对扩展开放,对修改关闭,所以出现了IMongoRepository接口). MongoDB学习笔记系列~目录 MongoDB学习笔记~环境搭建 (2015-03-30 10:34) M

MongoDB学习笔记一:MongoDB的下载和安装

趁着这几天比较空闲,准备学习一下MongoDB数据库,今天就简单的学习了一些MongoDB的下载和安装,并创建了存储MongoDB的数据仓库.将自己今天学习到的写成博客分享给大家. 一.MongoDB的下载和安装 MongoDB的下载地址为:http://www.mongodb.org/ 1.进入官网的首页后,在首页的右上方单击Downloads连接,如图所示: 2.在页面中可以看到目前最新的版本和以前发布过的版本,这里选择最新版本,windows 32位的进行下载,文件的格式为ZIP格式的,单

MongoDB 数据库,对象,集合 MongoDB学习平台

http://www.w3cschool.cc/mongodb/mongodb-databases-documents-collections.html MongoDB 数据库,对象,集合 描述 不管我们学习什么数据库都应该学习其中的基础概念,在mongodb中基本的概念是文档.集合.数据库,下面我们挨个介绍. 数据库 一个mongodb中可以建立多个数据库. MongoDB的默认数据库为"db",该数据库存储在data目录中. 在MongoDB中可以创建数据库,如果你想使用Mongo

MongoDB学习笔记(一:安装时出现The default storage engine 'wiredTiger' is not available问题解决)

今晚在自己老式笔记本来试了一下MongoDB的安装,由于配置比较低,只能选择32位版本的MongoDB进行安装,在安装过程中碰到了上述标题所示错误,自己也捣鼓了一个小时左右,终于在一篇博客中找到答案,具体原文链接如下:http://blog.csdn.net/u013457382/article/details/50775268 MongoDB学习笔记(一:安装时出现The default storage engine 'wiredTiger' is not available问题解决)

Mongodb学习笔记

总结下这几天Mongodb学习笔记 /** * 获取MongoClient * @author xuyw * @email [email protected] * @param host * @param port * @return */ public static MongoClient getMongoClient(String host, int... port) { MongoClient mongoClient = null; int portlen = 0; try { if (p

[Spring Data MongoDB]学习笔记--建立数据库的连接

1. 有了上一篇的Mongo后,连接数据库我们还需要更多的信息,比如数据库名字,用户名和密码等. 我们可以继续来配置MongoDbFactory的实例. public interface MongoDbFactory { DB getDb() throws DataAccessException; DB getDb(String dbName) throws DataAccessException; } 然后我们可以继续用MongoDbFactory来创建MongoTemplate的实例. pu

mongodb学习(三)

菜鸟啊...先吐槽一下自己 一 准备工作: 1.安装服务端: 去官网下载 http://www.mongodb.org/downloads 其实也自带了客户端 shell 2.安装客户端: mongoVUE http://blog.mongovue.com/ 并不是完全免费 破解方法: http://yhv5.com/mongovue_480.html 将服务端下载下来后直接安装 我下载在D盘也安装在D盘的... 启动mongodb的服务端不需要各种命令....直接鼠标左键双击bin中的mong

mongodb学习笔记系列一

一.简介和安装 ./bin/mongod --dbpath /path/to/database --logpath /path/to/log --fork --port 27017 mongodb非常的占磁盘空间, 刚启动后要占3-4G左右,--smallfiles 二.基本命令 1.登录mongodb client /use/local/mongo 2.查看当前数据库 show databases; show dbs; 两个可能 3.admin是和管理有关的库,local 是放schema有关