---恢复内容开始---

一、MVC代码结构模式

设计模式:观察者模式、中介者模式,这种模式,主要做的事情是处理类与类之间‘高内聚、低耦合’;

代码架构模式:MVC、MVVM、MVP

Model:模型,处理数据的模型。

View:视图部分,眼睛能看到的部分

Controller:控制器,是view(视图层)model(数据层)的一个桥梁;

二、数据库的学习

1、NOsql的学习

提示:NoSQL数据库分为四大类,咱们只是学习了其中一种mongoDB(文档型数据库);

2、安装MongoDB数据库

mongoDB官网:https://www.mongodb.com/

提示:①将压缩包解压到C:\program files文件夹当中

通过高级系统设置安装路径

在终端当中输入:mongo -version 如果有数据显示出来说明你的数据库安装成功;

3、开启数据库

如果你看到27017说明你的数据库开启了

-dbpath:代表的是你数据库仓库的路径

C:\database 就是你数据库仓库的路径

提示:如果你想操作数据库,开启数据库的这个终端命令窗口不能关闭,从新的在开启一个终端命令窗口操作数据库;

4、基本的操作-数据库

重点:操作数据的时候,数据库必须开启来;  开启数据库 mongod -dbpath  c:\database

第一步:mongo 开启REPL环境

第二步:use xsgl   ---创建数据库

第三步:咱们当年的mysql数据库咱们称作为表-但是在mongodb数据当中没有表的概念,它叫做集合(collection)

db.collection(集合的名字).insert(json):插入数据

第四步:查询全部的数据

查询数据:db.banji0920.find();     db.集合.find()

第五步:查询更加详细的数据

db.banji0920.find({"name":'xiaoming'})

5、增、查、改、删

http://www.runoob.com/mongodb/mongodb-dropdatabase.html 学习的地址

提示:操作数据库,一定要开启数据库。

    db.集合的名字.insert(json)

查    db.banji0920.find()->查询全部的数据

db.banji0920.find({“age”:17},{“sex”:’nv’}) ->查询的条件 且的形式

db.banji0920.find({“age”:{“$gt”:20}}) - >查询的条件是 要查询的数据的你年龄大于20岁的  大于

db.banji0920.find({“age”:{“$gte”:20}}) 大于等于

Db.banji0920.find({“age”:{“$lt”:20}})  小于

Db.banji0920.find({“age”:{“$lte”:20}}) 小于等于

db.banji0920.find({"$or":[{"name":"xiaogang"},{"name":"xiaozi"}]})  查询或的关系

 改        db.banji0920.find()

修改:db.banji0920.update({“name”:”xiaozi”},{“$set”:{“name”:xiaoxiami}});

两个参数:第一个参数修改的是谁      第二个参数:修改为什么

删 

show dbs  展示全部的数据库,但是咱们发现,默认一个叫做local的数据库

db.dropDatabase()     删除数据库

Show collections    查询全部的集合

db.banji110.drop()  ---删除集合

三、可视化工具的 使用(mongobooster)

四、node操作数据库-mongoDB

概述:原生的操作mongoDB不是重点,因为咱们一会会学习mongoose代替mongoDB

https://www.npmjs.com/package/mongodb

//在调用mongod模块的时候,这个对象打点一个属性MongoClient,返回一个MongoClient的对象
var MongoClient = require('mongodb').MongoClient; //数据库的地址
var url = 'mongodb://localhost:27017/xsgl'; //链接数据库
MongoClient.connect(url, function(err,db) { if(!err){
console.log("链接数据库成功");
}else{
console.log("链接数据库失败");
}
});

提示:①现在的db参数就是你的数据库对象,你就可以操作它;当你引入mongoose的时候,mongodb已经捎带脚的也下载进来了,因为mongoose需要mongodb的支持;

 五、mongooses模块

官方手册:https://www.npmjs.com/package/mongoose

概述:mongoose模块,简单了mongodb操作,也就说对原生的mongodb进行了封装;

第一步:创建身份证  cnpm init

第二步:    下载mongoose模块

第三步:创建咱们的app.js文件

//引入mongoose模块
var mongoose = require("mongoose");
//链接数据库
mongoose.connect("mongodb://localhost/xsgl",{useMongoClient:true});
cvar mongoose = require("mongoose");
//描述你存储数据的key是什么类型的
var schema = new mongoose.Schema({
'name':String,
'age':Number,
'xuehao':Number
}); //对外暴露一个类就可以了
var Student = mongoose.model("Student",schema); //暴露类
module.exports = Student;

六、mongooses增、删、改、查

//第一种方式
//增:
var xiaoming = new Student({
"name":"小明",
"age":18,
'xuehao':1001
});
//保存数据库
xiaoming.save((err)=>{
if(!err) console.log("添加成功");
})
//第二种方式
Student.create({"name":"小红","age":12,"xuehao":1002},function (err) {
if(!err) console.log("添加成功");
})

注意:咱们的集合是这个类名自动加了一个s

//这个删除的套路:先找到你要删除的数据,但是返回的是一个数组

//第一种方式
Student.find({"name":"小子"},function  (err,result) {
var zhegeren = result[0];
zhegeren.remove(function (err) {
if(!err) console.log("删除掉了");
});
})
//第二种方式
Student.remove({"age":18},function (err) {
if(!err) console.log("删除成功");
})

//第一种方式
Student.find({"name":"小红"},function (err,result) {
var obj = result[0];
obj.name = "贾成豪";
obj.save();
})
//第二种方式
//Update(更新的是谁,更新为什么,callBack)
Student.update({"name":"贾成豪"},{"$set":{"name":"小红"}},function (err) {
if(!err) console.log("更新成功");
})

Student.find({},function  (err,result) {
console.log(result);
})

node(3)MVC代码结构模式moogoDB的学习的更多相关文章

  1. jQuery 学习笔记:jQuery 代码结构

    jQuery 学习笔记:jQuery 代码结构 这是我学习 jQuery 过程中整理的笔记,这一部分主要包括 jQuery 的代码最外层的结构,写出来整理自己的学习成果,有错误欢迎指出. jQuery ...

  2. MVC5+EF6 入门完整教程十一:细说MVC中仓储模式的应用

    摘要: 第一阶段1~10篇已经覆盖了MVC开发必要的基本知识. 第二阶段11-20篇将会侧重于专题的讲解,一篇文章解决一个实际问题. 根据园友的反馈, 本篇文章将会先对呼声最高的仓储模式进行讲解. 文 ...

  3. 全端开发必备!10个最好的 Node.js MVC 框架

      Node.js 是最流行的 JavaScript 服务端平台,它允许建立可扩展的 Web 应用程序.Node.js 包含不同类型的框架,如 MVC 框架.全栈框架.REST API  以及大量的服 ...

  4. MVC5+EF6 入门完整教程11--细说MVC中仓储模式的应用

    摘要: 第一阶段1~10篇已经覆盖了MVC开发必要的基本知识. 第二阶段11-20篇将会侧重于专题的讲解,一篇文章解决一个实际问题. 根据园友的反馈, 本篇文章将会先对呼声最高的仓储模式进行讲解. 文 ...

  5. PHPWind 8.7中代码结构与程序执行顺序

    pw9在此不谈,他是完全重构的作品,是完全MVC下的体系.当然,其中很多东西在PW8.7下已经可见端倪. 主要代码结构 1. 以现代的观点,PW是多入口应用模式,程序根目录下的文件几乎都是入口: 2. ...

  6. 【360开源】thinkjs:基于Promise的Node.js MVC框架 (转)

    thinkjs是360奇舞团开源的一款Node.js MVC框架,该框架底层基于Promise来实现,很好的解决了Node.js里异步回调的问题.360奇舞团(奇虎75Team),是奇虎360公司We ...

  7. 细说MVC中仓储模式的应用

    文章提纲 概述要点 理论基础 详细步骤 总结 概述要点 设计模式的产生,就是在对开发过程进行不断的抽象. 我们先看一下之前访问数据的典型过程. 在Controller中定义一个Context, 例如: ...

  8. Django---定义、MVC和MTV模式、命令行工具、配置文件settings

    1.什么是web框架 框架,即framework,特指为解决一个开放性问题而设计的具有一定约束性的支撑结构,使用框架可以帮你快速开发特定的系统,简单地说,就是你用别人搭建好的舞台来做表演. 对于所有的 ...

  9. jQuery 源码分析(一) 代码结构

    jQuery是一个Javascript库,它支持链式操作方式,即对发生在同一个JQuery对象上的一组动作,可以直接接连写无需要重复获取对象.这一特点使得JQuery的代码无比优雅,而且有强大的选择器 ...

随机推荐

  1. Python基础3:字符编码

    http://www.jb51.net/article/64917.htm Python 编码为什么那么蛋疼? https://i.cnblogs.com/EditPosts.aspx?postid= ...

  2. js的事件学习笔记

    目录 0.参考 1.事件流 冒泡传播 事件捕获 2.事件绑定--onclick接口 onclick类的接口,只能注册一个同类事件 onclick类的接口,使用button.onclick = null ...

  3. EF基础知识小记五(一对多、多对多处理)

    本文主要讲EF一对多关系和多对多关系的建立 一.模型设计器 1.一对多关系 右键设计器新增关联 导航属性和外键属性可修改 2.多对多关系 右键设计器新增关联 模型设计完毕之后,根据右键设计器根据模型生 ...

  4. 关于注解Annotation第一篇

    注解的定义格式如下: public @interface 注解名 {定义体} 定义体就是方法的集合,每个方法实则是声明了一个配置参数.方法的名称作为配置参数的名称,方法的返回值类型就是配置参数的类型. ...

  5. 使用Quartz.net来执行定时任务

    Quartz.net使用方法:http://www.cnblogs.com/lizichao1991/p/5707604.html 最近,项目中需要执行一个计划任务,组长就让我了解一下Quartz.n ...

  6. npm run build之后生成的dist如何扔到服务器运行(npm run build之后如何本地运行)

    运行npm run build之后,会生成一个dist文件夹,里面的目录结构大概是这样的: 生成完的文件我们怎么来运行呢?直接在本地打开inde.html是无法运行的,打包的时候有提示: 构建文件应该 ...

  7. c#基础学习(0806)之抽象类实现多态

    首先,要判断是否使用抽象类,可以从下面两个方面进行判断: 1.是不是需要被实例化 2.父类中有没有默认的实现 如果不需要被实例化,父类中没有默认的实现,则用抽象类(否则用虚方法来实现) 下面举个简单的 ...

  8. C# 小软件部分(一)

    自己在空闲时分整合.编写了一款小软件程序,命名为魔法兔子,希望大家可以提出意见和指导,此篇文章主要为软件的部分截图和介绍. 软件详情: 1.首先是登录,注册界面. 可以注册自己的账号,后台是腾讯云服务 ...

  9. Java基础教程(18)--继承

    一.继承的概念   继承是面向对象中一个非常重要的概念,使用继承可以从逻辑和层次上更好地组织代码,大大提高代码的复用性.在Java中,继承可以使得子类具有父类的属性和方法或者重新定义.追加属性和方法. ...

  10. 【转】关于JTA,XA,ACID

    对于我们这种初学者,可能会使用spring带给我们的@Transactional,可能了解JTA,可能会使用jotm.atomikos,又会遇到一些名词XA,支持XA的数据库驱动等等诸多问题,然后就会 ...