MongoDB

一、MongoDB

1.1、NoSQL的简介

SQL(structured query language结构化查询语言)

SQL数据有一个最大的特点,限制每一个字段的类型

比如SQL数据库中的password是varchar(字符串)类型,此时如果由于业务的需要,要将password变为仅int(数字)类型,由于之前的所有数据都是varchar类型,所以拓展性有限

NoSQL(Not Only SQL)非结构化数据库

非结构化数据

{"id":10001,"name":"小明","age":12,"sex":"男"},
{"id":"G1002","name":"小红","age":13,"sex":"女","class":"3班","score":100},

每一个字段没有限制,比如id可以是数字也可以是字符串,中间互相转换也是允许的

总结

 

优点

缺点

SQL

适合严格类型的语言,对于查询非常有利

限制的字段的拓展性

NoSQL

不限制字段类型,每一条数据都有自己的表达形态

不适用于严格类型的使用

2.2、 MongoDB数据库的下载和安装

MongoDB数据就是NoSQL类型

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

下载

 

安装

  • 然后解压到c盘的Program Files文件夹中

  • 设置对应的环境变量

  • 查看是否安装成功了 window PowerShell中mongo -version

  • 输出了版本号,说明安装成功了 (缺少补丁 下载对应补丁就行)

1.3、Mogo数据库的简单操作

c盘根目录创建  database文件夹 管理数据库

工具

作用

mongod.exe

负责开机

mongo.exe

负责管理数据库

开机:mongod --dbpath c:\database 

创建数据库 use bai

创建之前先  执行 mongo 表示可以操作数据库

use代表的是使用和创建的意思,如果有该数据库代表的是使用,如果没有则表示创建

use bai  表示创建了  bai 的数据库

创建表   db.student.insert({"id":"1001","name","张三"........................})

建表和创建数据库一样,如果有代表进入否则代表新建

查看表 db.student.find()

find()代表查看所有

条件查询

比如要查找表中所有的男生

db.student.find({"sex":"男"})

查询大于18岁的男生

db.student.find({"sex":"男" ,"age":{"$gt":18}})

多条件查询使用逗号隔开,$gt表示大于某个条件,$lt表示小于某个条件

查找年龄大于18岁的男生,或者年龄小于17岁的女生

db.student.find({"$or":[{"sex":"男","age":{"$gt":18}},{"sex":"女","age":{"$lt":17}}]})

查看所有的数据库  show dbs

要想创建数据库必须最少有一条数据 否则查询的时候不显示

删除数据库  (bai)

  1. use bai
  2. db.dropDatabase()

删除名字class的表

db.class.drop()

删除某一个表中的某一条符合条件的数据

db.student.remove({"sex":"男"})

查看数据库中所以表

  1. 进入当前数据库 use bai
  2. show collections

1.4、数据的导入和导出

下载对应拓展工具  https://www.mongodb.com/try/download/database-tools?tck=docs_databasetools

解压后将mongoexport.ext和mongoimport.ext复制下来放到环境变量的bin文件夹内部

导入和导出的时候不要开启REPL(read eval print loop)环境,也就是不要在mongo命令之后

导入

mongoimport -d bai-c student C:\Users\QianchengPC\Desktop\data.txt

-d(database)表示的是导入到哪个数据库

-c(collections)表示的是哪个表(集合)

文件的路径不用自己手写,只需要将文件“扥”、“拽”进来即可

导出

mongoexport -d bai -c student -o C:\Users\QianchengPC\Desktop\beifen.txt

1.5、mongobooster可视化管理数据库软件

下载mongobooster 双击安装

二、Node.js操作MongoDB

node.js操作MongoDB,实际上问题还是比较多的

第一个每一个版本的迭代差异化比较大

第二个就是语法设置不利于我们进行大规模的开发,比如MVC编程的设计

三、Mongoose

官网地址:http://www.mongoosejs.net/

3.1、基本使用

创建项目   

npm init

安装  npm install --save mongoose

创建models 文件夹  创建 Superstar.js 文件

创建Superstar的构造函数

var mongoose = require("mongoose");
//创建schema  相当于创建数据库中表的表头
var SuperstarSchema = new mongoose.Schema({
    "name":String,
    "age":Number,
    "sex":String,
    "industry":String
});

//创建 model,底层创建构造函数

var Superstar = mongoose.model("Superstar",SuperstarSchema);
//向外暴露
module.exports = Superstar

app.js

var mongoose = require("mongoose");
//连接数据库
mongoose.connect("mongodb://localhost/bai");

//链接需要的 model 
var Superstar = require("./models/Superstar.js");

//新增
var kobe = new Superstar({
    "name":"科比布莱恩特",
    "age":43,
    "sex":"男",
    "industry":"篮球"
})

kobe.save(function (err) {
    if(!err){
        console.log("插入成功")
    }
})

数据库中的表会自动帮你转义,比如我们建的名字是Superstar会帮你加s,为Superstars

3.2、增加

var kobe = new Superstar({
    "name":"科比布莱恩特",
    "age":43,
    "sex":"男",
    "industry":"篮球"
})

kobe.save(function (err) {
    if(!err){
        console.log("插入成功")
    }
})
Superstar.create({
    "name":"周杰伦",
    "age":40,
    "sex":"男",
    "industry":"歌手"
},function (err) {
    !err && console.log("插入成功")
})

 3.3、删除

Superstar.find({"name":"周杰伦"},function (err,results) {
    results[0].remove(function (err) {
        !err && console.log("删除成功")
    })
})
Superstar.remove({"name":"周杰伦"},function (err) {
    !err && console.log("删除成功")
})

 3.4、修改

Superstar.find({"name":"科比布莱恩特"},function (err,results) {
    var temp =results[0]
    temp.age = 40;
    temp.save(function (err) {
        !err && console.log("修改成功")
    })
})
Superstar.update({"name":"科比布莱恩特"},{"$set":{"name":"勒布朗詹姆斯","age":37}},function (err) {
!err && console.log("修改成功")
}

3.5、查询

Superstar.find({"name":"小白"},function(err,results){
  console.log(results)
})

3.6、查询

返回查询出符合条件的 数量

        Superstar.count({"name":"小白"},function(err,count){
            console.log(count)
            res.json({"result":count})
        })

 

 

 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值