数据库和mongoose

 

  • 数据库

    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只是其中一种sql

    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 版权声明:本文为博主原创文章,转载请附上博文连接!mongodb

相关文章
相关标签/搜索