要求: 新增一个员工时,如果该员工已存在(以员工号f_emp_code作为判断依据),则更新,否则插入。而且工资f_salary,更新时,不得低于原工资(即:工资只能涨,不能降)。...(根据表上的唯一键),如果存在,先delete,然后再insert。...这个方法有一个很大的问题,如果记录存在,每次执行完,主键自增id就变了(相当于重新insert了一条),对于有复杂关联的业务场景,如果主表的id变了,其它子表没做好同步,会死得很难看。...该方法,没有replace into的副作用,不会导致已存在记录的自增id变化。...但是有另外一个问题,如果这个表上有不止一个唯一约束,在特定版本的mysql中容易产生dead lock(死锁),见网友文章https://blog.csdn.net/pml18710973036/article
handler(err) }) 更新 model 的 update 方法可以修改数据库中的文档,不过不会把文档返回给应用层。...如果想更新单独一条文档并且返回给应用层,可以使用 findOneAndUpdate 方法。 六、文档-Documents Mongoose document代表着MongoDB文档的一对一映射。...-SubDocuments 子文档是指嵌套在另一个文档中的文档。...Mongoose子文档有两种不同的概念:子文档数组和单个嵌套子文档 const chidlSchema = new Schema({name:String}) const parentSchema...= new Schema({ children:[childSchema], child:childSchema }) 子文档与文档的区别是 子文档不能单独保存,他们会在他们的顶级文档保存时保存
remove方法 4.Sub Docs 如同SQL数据库中2张表有主外关系,Mongoose将2个Document的嵌套叫做Sub-Docs(子文档) 简单的说就是一个Document嵌套另外一个...如果子文档在更新时出现错误,将直接报在父类文档中,可以这样处理: ChildrenSchema.pre('save',function(next){ if('x' === this.name... 如果children是parent的子文档,可以通过如下方法查询到children var child = parent.children.id(id); 4.2 新增、删除、更新 子文档是父文档的一个属性...,因此按照属性的操作即可,不同的是在新增父类的时候,子文档是会被先加入进去的。 ...如果ChildrenSchema是临时的一个子文档,不作为数据库映射集合,可以这样: var ParentSchema = new Schema({ children:{
如果出错,则 error 是出错信息,result 是 null;如果查询成功,则 error 是 null, result 是查询结果,查询结果的结构形式是根据查询方法的不同而有不同形式的。...更新 每个模型都有自己的更新方法,用于修改数据库中的文档,不将它们返回到您的应用程序。...sort:如果查询条件找到多个文档,则设置排序顺序以选择要更新哪个文档。 maxTimeMS:为查询设置时间限制。 upsert:布尔值,如果对象不存在,则创建它。默认值为 false。...omitUndefined:布尔值,如果为 true,则在更新之前删除值为 undefined 的属性。 rawResult:如果为 true,则返回来自 MongoDB 的原生结果。...,则设置排序顺序以选择要删除哪个文档。
非关系型数据库的解决思路: 在文章的Collection中增加一个SubCollection,SubCollection中可以存放用户信息,如用户名,只要有用户喜欢了文章,在这篇文章的文档中的子文档下插入一条记录即可...先学习以下Mongoose的基本用法 将Mongoose集成到项目中 npm install --save mongoose 连接数据库 var mongoose = require('mongoose...通过查找资料我的总结如下: 如果只需要通过A集合查询B集合,而不需要反过来查询,也就是单向的关系(如文章和评论,只需要展示文章的时候,将其评论展示即可),那么可以在A集合中建立一个子集合B。...如果既需要通过A查询B,又需要通过B查询A(如作者和文章,需要查询某作者下的所有文章,展示文章的时候,有需要展示作者的相关信息),那么可以在子集合中通过一个唯一字段关联父集合。...关于NodeJS中数据库的知识,就写这么多了,想要更多的了解有关Mongoose的用法,请参考官方文档:Mongoosejs Guide。文档写得非常详细! Have a good luck~
准备工作 let mongoose = require("mongoose"); let connection = require("....apple"},{name:"orange"}); console.log(result); })() image.png n是匹配的条件 nModified表示实际发生更新操作的条数 更新还涉及到...updateOne顾名思义如果找到多条记录,则只更新一条。...updateMany同理如果找到多条记录,则更新所有匹配的记录 删除 删除是艰巨的任务,毕竟删库跑路一直都备受关注,所以在使用的时候一定要小心☠。 默认的情况下remove删除所有匹配的记录。...我们在上面的准备工作里创建了一个UserScheme集合结构,在这里我们又创建ScoreSchema的表结构,在ScoreSchema结构里面uid是一个外键,类型是一个ObjectId类型,用于标志存储数据的唯一性
MongoDB 文档类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组,操作起来比较简单和容易。...ObjectId是一种特殊类型,用于唯一标识符,可以理解为主键,一般使用mongoose.Types.ObjectId。...更多的文档参考https://mongoosejs.com/docs/schematypes.html[5] ?有人可能会问为什么 ObjectId 可以做唯一标识符呢,不会重复吗?...2.5 ObjectId 一个 ObjectId 其实可以分割为四部分,即当前时间戳,当前主机的hash,当前进程id,自动增加的计数器,有了这几个基本上就可以保证它的唯一性了。...name:"vivo" }) user1.save().then(doc=>{ console.log(doc); }) 最后 本文结束,有什么问题和有错误的地方,欢迎大家的留言和评论,还有后续更新
现在已经有了 npm 的日志记录模块。这些模块可以将日志存储在不同格式或级别的文件中。我们将使用流行的ORM Mongoose 讨论 Node.js Express 程序中的 API 日志记录。...那么如何创建一个 Mongoose 插件,以更清洁的方式为你进行记录并简化 API 日志? Mongoose 中的插件是什么? 在 Mongoose 中,模式是可插入的。...函数和 DOM 节点则进行严格相等的比较,即使用 ===。 这里我们迭代每个对象的属性和值,并将它与旧对象进行比较。...this.isNew():如果你正在创建新文档,那么只需返回 next()中间件。 在 schema.post('init') 的 toObject()中: doc..../app/utils/diff-plugin')) 这是 user 更新 API 的基本示例: const User = require('..
4.查询文档 find()方法 返回一组文档 // 根据条件查找文档(条件为空则查找所有文档) Course.find().then(result => console.log(result)) //...// 删除单个文档 如果条件包含多个文档,默认删除符合条件的第一个文档 返回删除的文档 User.findOneAndDelete({ _id: '5c09f1e5aeb04b22f8460965...' }).then(result => { console.log(result); }); // 删除多个 如果条件为空,默认删除所有文档 返回一个对象,n代表删除的文档数,OK表示是否删除成功...查询条件}, {要更改的值}).then(result => console.log(result)) // 更新单条文档 如果条件满足多个文档,也是默认只更新第一个 User.updateOne...验证 在创建集合规则时,可以设置当前字段的验证规则,验证失败则插入失败。
生成短链接编码 这是我们实现的关键一步,思路是:用户传入一个长链接,我们首先使用 valid-url 判断传入的url是否合法,不合法则返回错误,如果合法我们在数据库中搜索是否有该长链接的记录,如果有则直接返回该条记录...,如果没有则生成一条新记录,并生成对应的短链接。...借助于 shortId,我们可以很方便的生成一个不重复的唯一编码。...访问短链接跳转到原链接 最后一步非常简单,当用户访问我们生成的短链接时,我们根据url中的短链接编码查询到对应记录,如果存在对应记录我们使用express的res.redirect方法将访问重定向至原链接...,如果不存在则返回错误。
MongoDB是一款流行的文档型数据库,可以在Node.js中使用官方的MongoDB包或者第三方包mongoose进行操作。...);根据 id 删除文档:Model.findByIdAndDelete(id, options, callback);更新(改)更新所有匹配条件的文档:Model.updateMany(filter,...update, options, callback);更新第一个匹配条件的文档:Model.updateOne(filter, update, options, callback);根据 id 更新文档...使用官方的 mongodb 包来操作 MongoDB 数据库官方的 mongodb 包提供了许多方法来操作 MongoDB 数据库,例如:连接数据库、创建集合、插入文档、查询文档、更新文档、删除文档等。...Schema 时需要指定集合(表)中每个字段的数据类型和约束条件,例如字段类型可以是 String、Number、Date、Boolean 等,约束条件可以是 required(必填项)、unique(唯一性
在项目根目录下输入以下命令导入 mongoimport -d 数据库名称 -c 集合名称 --file 要导入的数据文件 4.查询文档 find()方法 返回一组文档 // 根据条件查找文档(条件为空则查找所有文档...// 删除单个文档 如果条件包含多个文档,默认删除符合条件的第一个文档 返回删除的文档 User.findOneAndDelete({ _id: '5c09f1e5aeb04b22f8460965...' }).then(result => { console.log(result); }); // 删除多个 如果条件为空,默认删除所有文档 返回一个对象,n代表删除的文档数,OK表示是否删除成功...查询条件}, {要更改的值}).then(result => console.log(result)) // 更新单条文档 如果条件满足多个文档,也是默认只更新第一个 User.updateOne...验证 在创建集合规则时,可以设置当前字段的验证规则,验证失败则插入失败。
---- 更新记录:2018-4-9,md5加密 win10安装mongodb window下安装mongodb,需要参考的可以移步我的博客中:win10安装mongodb 项目初始化 本次项目使用的是...端口号根据后台设置来,默认是3000 changeOrigin: true, pathRewrite: { '^/api': '' // 若target中没有/api、这里又为空,则404...初始化一条数据 如果对mongodb,mongoose没有基础的了解,建议看一看mongoose深入浅出 ,mongoose基础操作 // controllers/student.js const...,子文档数组分页模糊查询 如下图是我的student集合: 在该集合中,学生参加过的考试记录,存在exams数组中,当想实现分页查询几条数据的时候,需要用到$slice $slice:[start...}) // .......................判断太长省略........................ }) }; 更新子文档数组
JSON风格的文档: MongoDB的文档采用JSON风格的格式,这使得数据在应用程序和数据库之间的映射更为自然。这种文档存储的方式也使得数据更易于理解和使用。...下载nodemon解决node代码更新的痛点 npm install nodemon -g 3. node.js连接mongodb数据库 npm install mongoose --save 后端目录...db.js const mongoose = require('mongoose') //连接mongodb数据库 mongoose.connect("mongodb://localhost:27017...const results = await Lose.find({ name }); if (results.length > 0) { // 如果找到匹配的记录...,则返回所有匹配的记录 res.json(results); } else { res.send("未找到匹配的记录");
: '一客', isPublished: true }); //将文档插入数据库中 course.save(); 通过集合构造函数方法(create)创建文档 const mongoose =.../user.json(导入文件) 查询文档 // 引入mongoose第三方模块 用来操作数据库 const mongoose = require('mongoose'); // 数据库连接 mongoose.connect...单个 如果更新条件匹配多个默认只更新第一个 deleteMany 多个 第一个条件为空 默认更新所有(慎用) // 引入mongoose第三方模块 用来操作数据库 const mongoose = require....then(result => console.log(result)) 更新修改文档 updateOne 单个 如果更新条件匹配多个默认只更新第一个 updateMany 多个 第一个条件为空 默认更新所有...('User', userSchema); // 找到要删除的文档并且删除 // 返回是否删除成功的对象 // 如果匹配了多条文档, 只会删除匹配成功的第一条文档 // User.updateOne({
,存储和操作的内容都是文档 字段 文档中的一条数据,属性名就是字段名 数据库和集合都不需要手动创建 当我们创建文档时,如果文档所在的集合或数据库不存在会自动创建 7 安装可视化工具 下载地址....insertMany(doc) 插入多个文档 下面两个方法更像是第一个方法的拆分,但是下面两个语义更加清晰 插入文档时,如果没有给文档指定 _id 属性,则数据库会自动为文档添加 _id,可以自己指定..._id 该属性为文档的唯一标识,不可重复,根据时间戳+机器码生成 ObjectId(),确保数据唯一 // 向 test 数据库中 person 集合插入一个新数据 {name:"张三",age:"18....remove({条件}) 删除符合条件的所有文档,第二个参数为 true 只删除一个 条件必须设置,如果没有直接删除所有文档 db....= require('mongoose'); 引入 mongoose 使用 mongoose.connect('mongodb://localhost/user_manage'); 如果使用默认端口号(
字段 文档中的一条数据,属性名就是字段名 数据库和集合都不需要手动创建 当我们创建文档时,如果文档所在的集合或数据库不存在会自动创建 7 安装可视化工具 下载地址:https://www.mongodbmanager.com....insertMany(doc) 插入多个文档 下面两个方法更像是第一个方法的拆分,但是下面两个语义更加清晰 插入文档时,如果没有给文档指定 _id 属性,则数据库会自动为文档添加 _id,可以自己指定..._id 该属性为文档的唯一标识,不可重复,根据时间戳+机器码生成 ObjectId(),确保数据唯一 // 向 test 数据库中 person 集合插入一个新数据 {name:"张三",age:"18....remove({条件}) 删除符合条件的所有文档,第二个参数为 true 只删除一个 条件必须设置,如果没有直接删除所有文档 db....'); 引入 mongoose 使用 mongoose.connect('mongodb://localhost/user_manage'); 如果使用默认端口号(27017),可以省略不写 监听
这个时候就要想该怎么做才能合理的管理这些层级关系,在删除父评论的同时又能把所有子评论一起删除。查询的时候如何去由根到叶顺序输出层级关系。...建立评论模型 js 1const schema = new mongoose.Schema({ 2 // comment id 3 cid: { 4 type: Number, 5 required...最关键的是 key 列,这个用来记录平行层级。...如 post 中的一篇 pid 为 11 的文章下有一条评论,那么 key 中命名 11#001,这是第一条评论,如果该评论下存在一条回复,则回复的 key 为 11#001#001,下层亦是如此。...#001 的评论只要使用正则匹配 /^11#001/即可,把匹配到的内容全部删除就可以不用管关联的 post 是否一致,以及 cid,而 key 的值可以从前端发起的请求中提取 cid,用 cid 去查这个唯一记录
docs/api.html#connection_Connection 这是最简单的连接字符串,当然还有其它形式,比如:连接密码、数据库连接设置、集群方式连式等等,这里解释了,用着了时候自行查询API文档...图中可以看出,密码更新成功!update方法基本可以满足所有更新! ...Model.findOneAndUpdate([conditions], [update], [options], [callback]) //找到一条记录并更新 删除 Model.remove...([conditions], [update], [options], [callback]) //查找一条记录并更新 写在之后... ...mongoose操作基本入门大致就是这些,自已试一下,入门完全没问题,并且比node-mongodb-native还是要简单明了一些, 在node.js中操作数据库,如果逻辑相对复杂时,大量的回调嵌套还是比较郁闷的
1.4 查询文档 // 根据条件查找文档(条件为空则查找所有文档) Course.find().then(result => console.log(result)) ?...删除多个文档 如果没有给出删除的文档 那么将删除所有文档 User.deleteMany({}).then(result => console.log(result)); ?...1.6 更新文档 更新单个文档 User.updateOne({name:'张三'},{name:'张三丰'}).then(result => console.log(result)) ?...更新过后的数据库 ? 更新多个文档 User.updateMany({}, {name: '张三丰'}).then(result => console.log(result)) 更新前 ?...更新后 ? mongoose验证 在创建集合规则时,可以设置当前字段的验证规则,验证失败就则输入插入失败。
领取专属 10元无门槛券
手把手带您无忧上云