首页 > 数据库技术 > 详细

数据库和mongoose

时间:2019-05-21 16:27:44      阅读:130      评论:0      收藏:0      [点我收藏+]

 

  • 数据库

    1. 关系型数据库
    • 概念:以行和列的形式存储数据,以便于用户理解。这一系列的行和列被称为表,一组表组成了数据库。表与表之间的数据记录有关系。
    • 常用的数据库有哪些:Access mySql SqlServer oracle db2等
    1. 非关系型数据库
    • 概念:用于超大规模数据的存储。(例如谷歌或Facebook每天为他们的用户收集万亿比特的数据)。这些类型的数据存储不需要固定的模式,无需多余操作就可以横向扩展。
    • 常用数据库:MongoDB,Redis,HBase,CouchDB等
    1. mongodb 和 sql区别
      1. sql 是 数据库 表 行
      2. NoSql 是 数据库 集合 文档
    2. bson是mongodb的数据存储格式
    3. bson是json的超集
    • 数据库功能是用来存储数据的。
    • 数据库分为关系系数据库和非关系型数据库(nosql)
    • 关系型数据库是由表和表之间的关系组成的,nosql是由集合组成的,集合下面是很多的文档。
    • 非关系型数据库文件存储格式为BSON(一种JSON的扩展)。
    1. mongodb数据库连接地址: mongodb://127.0.0.1:27017

    mongoose

    mongodb这个数据的操作肯定不止一种形式,mongoose只是其中一种

    mongoose操作流程

    1. 安装mongoose
      $ cnpm i mongoose -D
    2. 连接数据库
    var mongoose = require( ‘mongoose )
    //mongoose.connect(连接地址/数据库名称)
    mongoose.connect( ‘mongodb://127.0.0.1:27017/students‘ )
    
    1. Schema定义
    • 定义 Schema
    • 定义 Model
    • 定义 Entity
    // 1. 定义Schema// var studentsSchema = new mongoose.Schema( options ) //options是用来定义存储数据的数据类型var studentsSchema = new mongoose.Schema( {
    // 数据: 数据类型
    id: Number,
    name: String,
    age: Number
    })
    // 2. 定义模型// var studentsModel = mongoose.model( 集合名称,骨架 )var studentsModel = mongoose.model( ‘students‘, studentsSchema )
    // 3. 定义实体var students = new studentsModel()
    
    1. CURD 增删改查
    • 增加
     students.id = 1
     students.name = "yyb"
     students.age = 18
     
     students.save( ( error ) => {
     if( error ) throw error
    console.log( ‘存储成功‘ )
     })
    
    • 查询
        studentsModel.find({}, ( error, result) => {
            if( error ) throw error
            console.log( result[0]._id )
        })
    
    • 删除 ( 通过 id 找到对应数据来删除 )
        studentsModel.find({}, ( error, result) => {
            if( error ) throw error
            var id = result[0]._id
        studentsModel.findById( id, ( error, data ) => {
            if( error ) throw error
        //删除
        data.remove( () => {
        console.log( ‘删除成功‘ )
                })
            })
        })
    
    • 修改
        studentsModel.find( {} , ( error , result ) => {
            if( error ) throw error
            const id = result[1]._id
        studentsModel.findById( id , ( error , data ) => {
            if( error ) throw error
            data.name = " 1902 "
            data.save()
        })
    })
    
    1. MVC
    • M Model 数据
    • V View 视图
    • C Controller 控制器( 逻辑操作 )
      --> RMVC
      R Router 路由

数据库关系型数据库概念:以行和列的形式存储数据,以便于用户理解。这一系列的行和列被称为表,一组表组成了数据库。表与表之间的数据记录有关系。常用的数据库有哪些:Access mySql SqlServer oracle db2等非关系型数据库概念:用于超大规模数据的存储。(例如谷歌或Facebook每天为他们的用户收集万亿比特的数据)。这些类型的数据存储不需要固定的模式,无需多余操作就可以横向扩展。常用数据库:MongoDB,Redis,HBase,CouchDB等mongodb 和 sql区别sql 是 数据库 表 行NoSql 是 数据库 集合 文档bson是mongodb的数据存储格式bson是json的超集数据库功能是用来存储数据的。数据库分为关系系数据库和非关系型数据库(nosql)关系型数据库是由表和表之间的关系组成的,nosql是由集合组成的,集合下面是很多的文档。非关系型数据库文件存储格式为BSON(一种JSON的扩展)。mongodb数据库连接地址: mongodb://127.0.0.1:27017mongoosemongodb这个数据的操作肯定不止一种形式,mongoose只是其中一种
mongoose操作流程安装mongoose$ cnpm i mongoose -D连接数据库var mongoose = require( ‘mongoose )//mongoose.connect(连接地址/数据库名称)mongoose.connect( ‘mongodb://127.0.0.1:27017/students‘ )123Schema定义定义 Schema定义 Model定义 Entity// 1. 定义Schema// var studentsSchema = new mongoose.Schema( options ) //options是用来定义存储数据的数据类型var studentsSchema = new mongoose.Schema( {// 数据: 数据类型id: Number,name: String,age: Number})// 2. 定义模型// var studentsModel = mongoose.model( 集合名称,骨架 )var studentsModel = mongoose.model( ‘students‘, studentsSchema )// 3. 定义实体var students = new studentsModel()12345678910111213CURD 增删改查增加 students.id = 1 students.name = "yyb" students.age = 18  students.save( ( error ) => { if( error ) throw errorconsole.log( ‘存储成功‘ ) })12345678查询    studentsModel.find({}, ( error, result) => {        if( error ) throw error        console.log( result[0]._id )    })1234删除 ( 通过 id 找到对应数据来删除 )    studentsModel.find({}, ( error, result) => {        if( error ) throw error        var id = result[0]._id    studentsModel.findById( id, ( error, data ) => {        if( error ) throw error    //删除    data.remove( () => {    console.log( ‘删除成功‘ )            })        })    })1234567891011修改    studentsModel.find( {} , ( error , result ) => {        if( error ) throw error        const id = result[1]._id    studentsModel.findById( id , ( error , data ) => {        if( error ) throw error        data.name = " 1902 "        data.save()    })})123456789MVCM Model 数据V View 视图C Controller 控制器( 逻辑操作 )–> RMVCR Router 路由--------------------- 作者:weixin_45058102 来源:CSDN 原文:https://blog.csdn.net/weixin_45058102/article/details/90408920 版权声明:本文为博主原创文章,转载请附上博文链接!

数据库和mongoose

原文:https://www.cnblogs.com/zhaoyingzi/p/10900466.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!