Node进阶第七天

一、复习

一、索引

  数据库中,根据一个字段的值,来寻找一个文档,是很常见的操作。比如根据学号来找一个学生。这个学号是唯一的。只要有学号,就能唯一确认一个学生的文档。学号这个属性,就非常适合建立索引。这样查找就非常简单了。

explain来查看这个寻找过程。

这个语句,能够查看检索的过程。

建立索引,索引建立之后是2的原因是id也是索引。

这样,今后通过name寻找student文档的时候,速度非常快,因为能够快速的从索引表中,找到这个文档。

缺点就是插入每条数据的时候,事件变慢了,效率低了。但是换回来的就是寻找的速度快。

索引这个属性,所有文档都不能相同。

{unique:true}

二、Mongoose

是一个将Javascript对象与数据库产生关系的一个框架,object related model。操作对象,就是操作数据库了;对象产生了,同时也持久化了。

这个思路是Java三大框架SSH中Hibernate框架的思路。彻底改变了人们使用数据库的方式。

http://www.mongoose.com

//引包,并不需要引用mongodb这个包

const mongoose = require('mongoose');

mongoose.connect('mongodb://localhost/test');

const Cat = mongoose.model('Cat', { name: String });

const kitty = new Cat({ name: 'Zildjian' });

kitty.save().then(() => console.log('meow'));

上面的代码中,没有一个语句是明显的操作数据库,感觉都在创建类、实例化类、调用类的方法,都是在操作对象,但是数据库同步被持久了。

创建一个模型

mongoose.model(‘模型名字’,{“name”:String,”age”:Integer});

就可以被实例化

var kitty = new Cat({name:’ZildJian’});

然后这个实例就可以被save。

来个实例

db.js:

//引包

const mongoose = require('mongoose');

//创建数据库连接

var db = mongoose.createConnection('mongodb://localhost/hoho');

//监听open事件

db.once('open', function (callback) {

console.log('数据库成功连接');

});

//向外暴露db对象

module.exports = db;

student.js:

var mongoose = require('mongoose');

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

//创建了一个schema结构。

var studentSchema = new mongoose.Schema({

name: { type: String },

age: { type: Number },

sex: { type: String }

});

//创建了一个模型,就是学生模型,就是学生类。

//类是基于schema创建的。

var studentModel = db.model('mongoose', studentSchema);

//向外暴露

module.exports = studentModel;

基于类的方法(之前是基于对象的方法):

db.js:

//引包

const mongoose = require('mongoose');

//创建数据库连接

var db = mongoose.createConnection('mongodb://localhost/hoho');

//监听open事件

db.once('open', function (callback) {

console.log('数据库成功连接');

});

//向外暴露db对象

module.exports = db;

student.js:

var mongoose = require('mongoose');

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

//创建了一个schema结构。

var studentSchema = new mongoose.Schema({

name: { type: String },

age: { type: Number },

sex: { type: String }

});

//创建静态方法

studentSchema.statics.zhaoren = function (name, callback) {

return this.model('student').find({ name: name }, callback);

}

//创建修改的静态方法

studentSchema.statics.xiugai = function (conditions, update, options, callback) {

this.model('student').update(conditions, update, options, callback);

}

//创建了一个模型,就是学生模型,就是学生类

//类是基于schema创建的。

var studentModel = db.model('student', studentSchema);

//向外暴露

module.exports = studentModel;

app.js:

//定义了一个模型,学生模型,"学生类"

var Student = require('./models/student');

/*

//实例化了一个学生类

var xiaoming = new Student({"name":"小明","age":12,"sex":"男"})

//保存这个学生类 这个save是一个基于对象的操作

xiaoming.save(function(){

console.log('存储成功');

});

*/

//这是一个基于类的操作,表现力更加丰富(工厂)

// Student.create({

//     'name': '小红',

//     'age': 13,

//     'sex': '女'

// }, (err) => {

//     console.log('保存成功');

// });

Student.zhaoren('小红', function (err, result) {

console.log(result);

});

Student.xiugai({ "name": "小红" }, { $set: { "age": 30 } }, {}, function () {

console.log('改年龄成功');

});

//我命令的是student类,没有命令db,并不是直接操作数据库的语句。

mongoose首先要想明白一件事儿,所有的操作都不是对数据库尽心地。所有地操作都是对类或者对象来操作的,数据库的持久化自动完成了。

创造schema->定义一些schema的静态方法->创造模型

创造schema用什么语句? new mongoose.schema({});

创造模型用什么语句?db.model(“Student”,schema 名字);

前台界面:不操作数据库,只操作类!

图书管理系统

借助mongoose做一个图书管理系统。

db.js:

//引包

const mongoose = require('mongoose');

//创建数据库连接

var db = mongoose.createConnection('mongodb://localhost/hoho');

//监听open事件

db.once('open', function (callback) {

console.log('数据库成功连接');

});

//向外暴露db对象

module.exports = db;

student.js:

var mongoose = require('mongoose');

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

//创建了一个schema结构。

var studentSchema = new mongoose.Schema({

name: { type: String },

age: { type: Number },

sex: { type: String }

});

//创建静态方法

studentSchema.statics.zhaoren = function (name, callback) {

return this.model('student').find({ name: name }, callback);

}

//创建修改的静态方法

studentSchema.statics.xiugai = function (conditions, update, options, callback) {

this.model('student').update(conditions, update, options, callback);

}

//创建了一个模型,就是学生模型,就是学生类

//类是基于schema创建的。

var studentModel = db.model('student', studentSchema);

//向外暴露

module.exports = studentModel;

app.js:

//定义了一个模型,学生模型,"学生类"

var Student = require('./models/student');

/*

//实例化了一个学生类

var xiaoming = new Student({"name":"小明","age":12,"sex":"男"})

//保存这个学生类 这个save是一个基于对象的操作

xiaoming.save(function(){

console.log('存储成功');

});

*/

//这是一个基于类的操作,表现力更加丰富(工厂)

// Student.create({

//     'name': '小红',

//     'age': 13,

//     'sex': '女'

// }, (err) => {

//     console.log('保存成功');

// });

Student.zhaoren('小红', function (err, result) {

console.log(result);

});

Student.xiugai({ "name": "小红" }, { $set: { "age": 30 } }, {}, function () {

console.log('改年龄成功');

});

//我命令的是student类,没有命令db,并不是直接操作数据库的语句。

Node_进阶_7的更多相关文章

  1. Node_进阶_8

    Node进阶第八天 一.复习 Node.js特点:单线程.异步I/O(非阻塞I/O).事件驱动(事件环). 适合的程序:就是没有太多的计算,I/O比较多的业务. 举例:留言本.考试系统.说说.图片裁切 ...

  2. Node_进阶_6

    Node进阶第六天 一.复习 cookie是在res中设置,req中读取的.第一次的访问没有cookie. cookie的存储大小有限,kv对儿.对用户可见,用户可以禁用.清除cookie.可以被篡改 ...

  3. Node_进阶_5

    Node进阶第五天 为什么mysql不用开mongod –dbpath xx… 答:因为mysql会在”服务”中运行,也就是开机时自动启动并且长久驻扎在内存中了. mongodb其实也能通过设置来设成 ...

  4. Node_进阶_4

    Node进阶第四天 一.传统数据库技术回顾 数据库就是存储数据的,那么存储数据用txt就行了啊,为什么要有数据库? 理由之一:数据库有行.列的概念,数据有关系,数据不是散的. 老牌数据库,比如Mysq ...

  5. React-Native进阶_7.TextInput的使用实现搜索功能

    前面使用TabBar 实现了底部tab标签,通过stackNavigator 实现了页面跳转,接下来,使用TextInput 来实现一个搜索功能. TextInput 属性比较多,不一一介绍,具体可以 ...

  6. Node_进阶_2

    第二天 一.复习: Node.js开发服务器.数据.路由.本地关心效果,交互. Node.js实际上是极客开发出的一个小玩具,不是银弹.有着别人不具备的怪异特点: 单线程.非阻塞I/O.事件驱动. 实 ...

  7. Node_进阶_1

    第一天 1.1简介 Node.js简介 V8引擎本身就是用于Chrome浏览器的JS解释部分,Ryan Dahl把这个V8搬到了服务器上,用于做服务器的软件. Node.js是一个让Javascrip ...

  8. Node_进阶_3

    Express框架: 一.   Express框架 Express框架是后台的Node框架,类似于JS中的jquery. #原生Node开发会有很多问题: 1呈递静态页面很不方便,需要处理每个HTTP ...

  9. PythonI/O进阶学习笔记_7.python动态属性,__new__和__init__和元类编程(上)

    content: 上: 1.property动态属性 2.__getattr__和__setattr__的区别和在属性查找中的作用 3.属性描述符 和属性查找过程 4.__new__和__init__ ...

随机推荐

  1. 手游服务器端接入facebook的SDK

    手游如果支持facebook登录,就要接入facebook的登录SDK.刚好工作中自己做了这一块的接入功能现在记录分享下来提供一个参考. 当前只是接入了登录这个功能,先简单的说说接入facebook登 ...

  2. Shell(五)Shell输入/输出重定向

    Shell 输入/输出重定向 大多数 UNIX 系统命令从你的终端接受输入并将所产生的输出发送回​​到您的终端.一个命令通常从一个叫标准输入的地方读取输入,默认情况下,这恰好是你的终端.同样,一个命令 ...

  3. VUE使用中踩过的坑

    前言 vue如今可谓是一匹黑马,github star数已居第一位!前端开发对于vue的使用已经越来越多,它的优点就不做介绍了,本篇是我对vue使用过程中以及对一些社区朋友提问我的问题中做的一些总结, ...

  4. 自适应增强(Adaptive Boosting)

    简介 AdaBoost,是英文”Adaptive Boosting“(自适应增强)的缩写,是一种迭代提升算法,其核心思想是针对同一个训练集训练不同的分类器(弱分类器),然后把这些弱分类器集合起来,构成 ...

  5. 洛谷10月月赛II

    #A: P4924 [1007]魔法少女小Scarlet 这道题考了矩阵旋转 其实很考验推公式的能力和代码能力 这里有个小技巧 可以设(x, y)为原点,然后去推公式,然后实际操作中横坐标加上x,纵坐 ...

  6. HDU 2155 Matrix

    Matrix Time Limit: 3000ms Memory Limit: 65536KB This problem will be judged on PKU. Original ID: 215 ...

  7. HDU 4318 Contest 2

    简单的一题,使用类DIJK的算法就可以了. #include <iostream> #include <cstdio> #include <queue> #incl ...

  8. hello world to php( mac 配置 xmapp virtual host)

    一.安装xmapp.安装完以后查看,服务是否都能启动(数据库和server) 二.配置自己的virtualhost       1.系统host文件加入server的域名(在浏览器中输入域名后会先通过 ...

  9. android的架构图

    1.Applications 该层是Android应用程序层. 每一个应用必须利用android系统设计的应用框架(application framework)开发. 眼下的开发环境是eclipse ...

  10. hashmap 循环取出全部值 取出特定的值 两种方法

    //第一种 Iterator menus = menu.iterator(); while(menus.hasNext()) { Map userMap = (Map) menus.next(); S ...