一、mongoose介绍

Mongoose 是在 node.js 异步环境下对 mongodb 进行便捷操作的对象模型工具。 Mongoose

是 NodeJS 的驱动, 不能作为其他语言的驱动。

Mongoose 有两个特点:

1、 通过关系型数据库的思想来设计非关系型数据库
2、 基于 mongodb 驱动, 简化操作

二、mongoose的安装以及使用

1.安装

npm/cnpm mongoose --save

2.引入mongoose并连接数据库

const mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/test');
如果有账户密码需要采用下面的连接方式:
mongoose.connect('mongodb://eggadmin:123456@localhost:27017/eggcms');

3.定义Schema

数据库中的 Schema, 为数据库对象的集合。 schema 是 mongoose 里会用到的一种数据模式,
可以理解为表结构的定义; 每个 schema 会映射到 mongodb 中的一个 collection, 它不具备
操作数据库的能力

var UserSchema=mongoose.Schema({
name: String,
age:Number,
status:'number'
})

4.创建数据模型

model 是由 schema 生成的模型, 可以对数据库的操作。

注意: mongoose.model 里面可以传入两个参数也可以传入三个参数

mongoose.model(参数 1:模型名称(首字母大写) , 参数 2:Schema)

传两个参数,默认会和模型名称相同的复数的集合建立连接,例如模型名称为"User",则会默认操作users这个集合

var User=mongoose.model('User', UserSchema);

mongoose.model(参数 1:模型名称(首字母大写) , 参数 2:Schema, 参数 3:数据库集合名称)

传三个参数,会和第三个参数的集合建立连接,操作第三个参数的集合

var User=mongoose.model('User', UserSchema,'users');
5.查找数据

User.find({},function(err,docs){
  if(err){
    console.log(err);
    return;
  }
  console.log(docs);
})

6.增加数据

var u=new User({ //实例化模型 传入增加的数据
  name:'lisi2222333',
  age:20,
  status:true
})
u.save(function(err,docs){
  if(err){
    console.log(err);
    return;
  }
  console.log(docs);
})

7.修改数据

User.updateOne({ name: 'lisi2222' }, { name: '哈哈哈' }, function(err, res) {
  if(err){
    console.log(err);
    return;
  }
  console.log('成功')
});

8.删除数据

User.deleteOne({ _id: '5b72ada84e284f0acc8d318a' }, function (err) {
  if (err) {
    console.log(err);
    return;
  }
  // deleted at most one tank document
  console.log('成功');
});

9.保存成功查找

var u=new User({
  name:'lisi2222333',
  age:20,
  status:true //类型转换
})
u.save(function(err,docs){
  if(err){
    console.log(err);
    return;
  }
  //console.log(docs);
  User.find({},function(err,docs){
  if(err){
    console.log(err);
    return;
  }
  console.log(docs);
  })
});

三、默认参数

在定义schema时,设置默认参数

var UserSchema=mongoose.Schema({
name:String,
age:Number,
status:{
type:Number,
default:1 //默认为1
}
})

四、模块化

1.先创建数据库连接模块moongoose

//连接数据库

var mongoose=require('mongoose');

//useNewUrlParser这个属性会在url里识别验证用户所需的db,未升级前是不需要指定的,升级到一定要指定。

mongoose.connect('mongodb://127.0.0.1:27017/eggcms',{ useNewUrlParser: true },function(err){
if(err){ console.log(err);
return;
}
console.log('数据库连接成功')
}); module.exports=mongoose; //输出mongoose

2.创建user模块

var mongoose=require('./db.js');

var UserSchema=mongoose.Schema({
name:String,
age:Number,
status:{
type:Number,
default:1
}
}) module.exports=mongoose.model('User',UserSchema,'user');

3.创建news模块

var mongoose=require('./db.js');

var NewsSchema=mongoose.Schema({
title:"string",
author:String,
pic:String,
content:String,
status:{ type:Number,
default:1 }
}) module.exports=mongoose.model('News',NewsSchema,'news');

4.使用模块

var UserModel=require('./model/user.js');

var NewsModel=require('./model/news.js');

var user=new UserModel({

    name:"李四666",
age:40
}) user.save(function(err){
if(err){ console.log(err);
return;
}
//获取user表的数据 UserModel.find({},function(err,docs){
if(err){ console.log(err);
return;
}
console.log(docs);
})
})
// NewsModel.find({},function(err,docs){ // if(err){ // console.log(err);
// return;
// }
// console.log(docs);
// })

五、模块性能

多个模块,不会多次连接数据库,只会在引入第一个模块时连接数据库

可以通过以下代码测试

console.time('user');

var UserModel=require('./model/user.js');

console.timeEnd('user');

console.time('news');
var NewsModel=require('./model/news.js'); console.timeEnd('news');

结果是:第一次时间大于第二次

MongoDB学习day07--mongoose入门,数据库增删改查,默认参数,模块化的更多相关文章

  1. MongoDB学习总结(二) —— 基本操作命令(增删改查)

    上一篇介绍了MongoDB在Windows平台下的安装,这一篇介绍一下MongoDB的一些基本操作命令. 下面我们直奔主题,用简单的实例依次介绍一下. > 查看所有数据库 (show dbs) ...

  2. 2. MongoDB基本操作 —— 用Mongo.exe操作数据库增删改查

    一.开篇 传统的关系数据库一般由数据库(database).表(table).记录(record)三个层次概念组成,MongoDB是由数据库(database).集合(collection).文档对象 ...

  3. mongodb 数据库 增删改查

    mongodb    数据库      增删改查 增: // 引入express 模块 var express = require('express'); // 路由var router = expr ...

  4. Android(java)学习笔记193:利用谷歌API对数据库增删改查(推荐使用)

    接下来我们通过项目案例来介绍:这个利用谷歌API对数据库增删改查 1.首先项目图: 2.这里的布局文件activity_main.xml: <LinearLayout xmlns:android ...

  5. 数据库学习之数据库增删改查(另外解决Mysql在linux下不能插入中文的问题)(二)

    数据库增删改查 增加 首先我们创建一个数据库user,然后创建一张表employee create table employee( id int primary key auto_increment, ...

  6. Android(java)学习笔记136:利用谷歌API对数据库增删改查(推荐使用)

    接下来我们通过项目案例来介绍:这个利用谷歌API对数据库增删改查 1. 首先项目图: 2. 这里的布局文件activity_main.xml: <LinearLayout xmlns:andro ...

  7. (转)SQLite数据库增删改查操作

    原文:http://www.cnblogs.com/linjiqin/archive/2011/05/26/2059182.html SQLite数据库增删改查操作 一.使用嵌入式关系型SQLite数 ...

  8. Yii2.0高级框架数据库增删改查的一些操作

    yii2.0框架是PHP开发的一个比较高效率的框架,集合了作者的大量心血,下面通过用户为例给大家详解yii2.0高级框架数据库增删改查的一些操作 --------------------------- ...

  9. MyBatis学习 之 二、SQL语句映射文件(2)增删改查、参数、缓存

    目录(?)[-] 二SQL语句映射文件2增删改查参数缓存 select insert updatedelete sql parameters 基本类型参数 Java实体类型参数 Map参数 多参数的实 ...

  10. Android SQLite 数据库 增删改查操作

    Android SQLite 数据库 增删改查操作 转载▼ 一.使用嵌入式关系型SQLite数据库存储数据 在Android平台上,集成了一个嵌入式关系型数据库--SQLite,SQLite3支持NU ...

随机推荐

  1. SOE 第五章

    SEO第五章 本次课目标: 1.  掌握代码优化 2.  掌握内链优化 一.代码优化 1)<h>标签 代表网页的标题,总共6个级别(h1-h6) 外观上显示字体的大小的修改,其中<h ...

  2. 解决Homestead yarn , npm run dev, 命令报错问题!

    解决Homestead yarn , npm run dev, 命令报错问题! 2018年06月01日 11:50:51 偶尔发发颠 阅读数:1654    版权声明:本文为博主原创,未经博主同意,不 ...

  3. core mvc 分页

    看了下XPAGE感觉还是用的不太爽,自己写了个,样式是bootstrap的,需要的小伙伴拿走吧. public static IHtmlContent Pager(this IHtmlHelper h ...

  4. python基础一 day9 函数升阶(1)

    函数 可读性强 复用性强def 函数名(): 函数体 return 返回值所有的函数 只定义不调用就一定不执行 先定义后调用 函数名() #不接收返回值返回值 = 函数名() #接收返回值 返回值 没 ...

  5. P2964 [USACO09NOV]硬币的游戏A Coin Game (DP)

    题意:n颗硬币 两个人从前往后按顺序拿 如果上一个人拿了i颗 那么下一个可以拿1-2*i颗 问先手能获得的最大收益 题解:比较典型的最大最小最大最小..DP了 但是暴力做的话是n^3 所以就体现出了这 ...

  6. 全志T8智能汽车方案芯片参数介绍

    T8处理器代表了Allwinner在智能汽车市场上的最新成就.T8适用于需要三维图形.高级视频处理.精密相机.多种连接选项和高水平系统集成的应用程序.它将把先进的消费电子体验带入未来的汽车,实现高性能 ...

  7. ios 封装sqllite3接口

    2013-03-25 17:41 261人阅读 评论(0) 收藏 举报 // #import <Foundation/Foundation.h> #import "sqlite3 ...

  8. MYSQL数据库攻防与加固

    这是“官方”原本的模样搬过来的..写的很粗略啊.还有篇详细的请查看:MySQL安全加固题目及答案参考解析 启动xserver-mysql,进入xserver-mysql,开始实验,实验步骤如下: 1. ...

  9. EPT和VPID简介

    EPT(Extended Page Tables,扩展页表),属于Intel的第二代硬件虚拟化技术,它是针对内存管理单元(MMU)的虚拟化扩展.EPT降低了内存虚拟化的难度(与影子页表相比),也提升了 ...

  10. 如何用纯 CSS 创作一种有削铁如泥感觉的菜单导航特效

    效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/XqYroe 可交互视频教 ...