【MongoDB】CURD+mongoose的CURD

it2024-03-21  77

命令式基本操作

MongoDB - MongoDB是一个NoSQL的数据库 - MongoDB是一款文档型数据库 - 数据库指的就是一个存储数据的仓库 数据库可以使我们完成对数据的持久化的操作 - MongoDB数据库中存储的数据的基本单位就是文档, MongoDB中存储的就是文档,所谓文档其实就是一个“JSON- MongoDB中的“JSON”我们称为BSON,比普通的JSON的功能要更加的强大 - MongoDB数据库使用的是JavaScript进行操作的,在MongoDB含有一个对ES标准实现的引擎, 在MongoDB中所有ES中的语法中都可以使用 - 基本概念 数据库(database) 集合(collection) 文档(document) - 在MongoDB中,数据库和集合都不需要手动创建,当我们创建文档时,如果文档所在的集合或数据库不存在会自动创建数据库和集合 - MongoDB的基本的指令 - 启动服务器 mongod --dbpath 路径 --port 端口号 - 启动客户端 mongo - MongoDB的CRUD的操作 - 基本操作 use 数据库 - 进入指定的数据库 show dbs - 显示所有的数据库 show collections - 显示数据库中所有的集合 db - 显示当前所在的数据库 - 向数据库中插入文档 - db.collection.insert() - insert()可以向集合中插入一个或多个文档 - db.collection.insertOne() - 向集合中插入一个文档 - db.collection.insertMany() - 向集合中插入多个文档 - 查询数据库中的文档 - db.collection.find() - 可以根据指定条件从集合中查询所有符合条件的文档 - 返回的是一个数组 - db.collection.findOne() - 查询第一个符合条件的文档 - 返回的是一个对象 - db.collection.find().count() - 查询符合条件的文档的数量 - 修改数据库中的文档 - db.collection.update() - 可以修改、替换集合中的一个或多个文档 - db.collection.updateOne() - 修改集合中的一个文档 - db.collection.updateMany() - 修改集合中的多个文档 - db.collection.replaceOne() - 替换集合中的一个文档 PS:如果需要修改指定的属性,而不是替换对象,需要使用“修改操作符”来完成修改 $set 可以用来修改文档中的指定属性 $unset 可以用来删除文档的指定属性 - 删除集合中的文档 - db.collection.remove() - 删除集合中的一个或多个文档(默认删除多个) - db.collection.deleteOne() - 删除集合中的一个文档 - db.collection.deleteMany() - 删除集合中的多个文档 - 清空一个集合 db.collection.remove({}) - 删除一个集合 db.collection.drop() - 删除一个数据库 db.dropDatabase()

示例

//向username为sunwukong的文档中,添加一个hobby:{cities:["beijing","shanghai","shenzhen"] , movies:["sanguo","hero"]} //MongoDB的文档的属性值也可以是一个文档,当一个文档的属性值是一个文档时,我们称这个文档叫做 内嵌文档 db.users.update({username:"sunwukong"},{$set:{hobby:{cities:["beijing","shanghai","shenzhen"] , movies:["sanguo","hero"]}}}); //查询喜欢电影hero的文档 //MongoDB支持直接通过内嵌文档的属性进行查询,如果要查询内嵌文档则可以通过.的形式来匹配 //如果要通过内嵌文档来对文档进行查询,此时属性名必须使用引号 db.users.find({'hobby.movies':"hero"}); //向tangseng中添加一个新的电影Interstellar //$push 用于向数组中添加一个新的元素 //$addToSet 向数组中添加一个新元素 , 如果数组中已经存在了该元素,则不会添加 db.users.update({username:"tangseng"},{$push:{"hobby.movies":"Interstellar"}}); db.users.update({username:"tangseng"},{$addToSet:{"hobby.movies":"Interstellar"}}); //查询numbers中num大于40小于50的文档 db.numbers.find({num:{$gt:40 , $lt:50}}); //查看numbers集合中的第11条到20条数据 /* 分页 每页显示10条 1-10 0 11-20 10 21-30 20 。。。 skip((页码-1) * 每页显示的条数).limit(每页显示的条数); skip()用于跳过指定数量的数据 MongoDB会自动调整sort、skip和limit的位置 先sort再skip最后limit */ db.numbers.find().skip(10).limit(10); //同db.numbers.find().limit(10).skip(10); //查看numbers集合中的第21条到30条数据 db.numbers.find().skip(20).limit(10); //查询工资小于1000或大于2500的员工 db.emp.find({$or:[{sal:{$lt:1000}} , {sal:{$gt:2500}}]}); //为所有薪资低于1000的员工增加工资400元 db.emp.updateMany({sal:{$lte:1000}} , {$inc:{sal:400}}); //查询文档时,默认情况是按照_id的值进行排列(升序) //sort()可以用来指定文档的排序的规则,sort()需要传递一个对象来指定排序规则 1表示升序 -1表示降序 //limit skip sort 可以以任意的顺序进行调用 db.emp.find({}).sort({sal:1,empno:-1}); //在查询时,可以在第二个参数的位置来设置查询结果的 投影 db.emp.find({},{ename:1 , _id:0 , sal:1});

mongoose

API文档

/* 1.下载安装Mongoose npm i mongoose --save 2.在项目中引入mongoose var mongoose = require("mongoose"); 3.连接MongoDB数据库 mongoose.connect('mongodb://数据库的ip地址:端口号/数据库名', { useMongoClient: true}); - 如果端口号是默认端口号(27017) 则可以省略不写 4.断开数据库连接(一般不需要调用) - MongoDB数据库,一般情况下,只需要连接一次,连接一次以后,除非项目停止服务器关闭,否则连接一般不会断开 mongoose.disconnect() - 监听MongoDB数据库的连接状态 - 在mongoose对象中,有一个属性叫做connection,该对象表示的就是数据库连接 通过监视该对象的状态,可以来监听数据库的连接与断开 数据库连接成功的事件 mongoose.connection.once("open",function(){}); 数据库断开的事件 mongoose.connection.once("close",function(){}); Schema Model Document */

1.Schema

var mongoose = require("mongoose"); mongoose.connect("mongodb://127.0.0.1/mongoose_test",{useMongoClient:true}); mongoose.connection.once("open",function () { console.log("数据库连接成功~~~"); }); //将mongoose.Schema 赋值给一个变量 var Schema = mongoose.Schema; //创建Schema(模式)对象 var stuSchema = new Schema({ name:String, age:Number, gender:{ type:String, default:"female" }, address:String });

2.Model

//通过Schema来创建Model //Model代表的是数据库中的集合,通过Model才能对数据库进行操作 //mongoose.model(modelName, schema): //modelName 就是要映射的集合名 mongoose会自动将集合名变成复数 var StuModel = mongoose.model("student" , stuSchema); /* - 有了Model,我们就可以来对数据库进行增删改查的操作了 Model.create(doc(s), [callback]) - 用来创建一个或多个文档并添加到数据库中 - 参数: doc(s) 可以是一个文档对象,也可以是一个文档对象的数组 callback 当操作完成以后调用的回调函数 查询的: Model.find(conditions, [projection], [options], [callback]) - 查询所有符合条件的文档 总会返回一个数组 Model.findById(id, [projection], [options], [callback]) - 根据文档的id属性查询文档 Model.findOne([conditions], [projection], [options], [callback]) - 查询符合条件的第一个文档 总和返回一个具体的文档对象 conditions 查询的条件 projection 投影 需要获取到的字段 - 两种方式 {name:1,_id:0} "name -_id" options 查询选项(skip limit) {skip:3 , limit:1} callback 回调函数,查询结果会通过回调函数返回 回调函数必须传,如果不传回调函数,压根不会查询 修改的: Model.update(conditions, doc, [options], [callback]) Model.updateMany(conditions, doc, [options], [callback]) Model.updateOne(conditions, doc, [options], [callback]) - 用来修改一个或多个文档 - 参数: conditions 查询条件 doc 修改后的对象 options 配置参数 callback 回调函数 Model.replaceOne(conditions, doc, [options], [callback]) 删除的: Model.remove(conditions, [callback]) Model.deleteOne(conditions, [callback]) Model.deleteMany(conditions, [callback]) */ //向数据库中插入一个文档 //StuModel.create(doc, function(err){}); StuModel.create({ name:"白骨精", age:16, address:"白骨洞" },function (err) { if(!err){ console.log("插入成功~~~"); } });

3.Document

//Document 和 集合中的文档一一对应 , Document是Model的实例,通过Model查询到结果都是Document 其方法为API中的Model#方法 /* get(name) - 获取文档中的指定属性值 set(name , value) - 设置文档的指定的属性值 id - 获取文档的_id属性值 toJSON() ****** - 转换为一个JSON对象 toObject() - 将Document对象转换为一个普通的JS对象 转换为普通的js对象以后,注意所有的Document对象的方法或属性都不能使用了 */ var obj = doc.toObject(); //对于id的访问 doc.id obj._id delete obj.address; //删除普通对象属性
最新回复(0)