当前位置: 首页 > news >正文

又名林州站长网会展行业门户网站建设

又名林州站长网,会展行业门户网站建设,新乡高端网站建设,企业管理咨询公司经营范围有哪些基本常用命令 MongoDB常用命令a) 案例需求b) 数据库操作b.1) 选择和创建数据库b.2) 删除数据库 c) 集合操作c.1) 集合的显示创建c.2) 集合的隐式创建c.3) 集合的删除 d) 文档基本CRUDd.1) 文档的插入(1) 单个文档的插入(2) 批量插入 d.2) 文档的基本查询(1) 查询所有(2) 投影查… 基本常用命令 MongoDB常用命令a) 案例需求b) 数据库操作b.1) 选择和创建数据库b.2) 删除数据库 c) 集合操作c.1) 集合的显示创建c.2) 集合的隐式创建c.3) 集合的删除 d) 文档基本CRUDd.1) 文档的插入(1) 单个文档的插入(2) 批量插入 d.2) 文档的基本查询(1) 查询所有(2) 投影查询(Projection Query) d.3) 文档的更新(1) 覆盖的修改(2) 局部的修改(3) 批量的修改(4) 列值增长的修改 d.4) 文档的删除 e) 文档的分页查询e.1) 统计查询(1) 统计所有记录数(2) 按条件统计记录数 e.2) 分页列表查询e.3) 排序查询 f) 文档的更多查询f.1) 正则的复杂条件查询f.2) 比较查询f.3) 包含查询f.4) 条件连接查询 g) 常用命令总结 MongoDB常用命令 a) 案例需求 存放文章评论的数据存放到MongoDB中数据结构参考如下 数据库articledb 专栏文章评论comment字段名称字段含义字段类型备注_idIDObjectId或StringMongo的主键的字段articleid文章IDStringcontent评论内容Stringuserid评论人IDStringnickname评论人昵称Stringcreatedatetime评论的日期时间Datelikenum点赞数Int32replynum回复数Int32state状态String0不可见1可见parentid上级IDString如果为0表示文章的顶级评论 b) 数据库操作 b.1) 选择和创建数据库 选择和创建数据库的语法格式 use 数据库名称如果数据库不存在则自动创建例如以下语句创建 spitdb 数据库 use articledb查看有权限查看的所有的数据库命令 show dbs 或 show databases注意:在 MongoDB 中集合只有在内容插入后才会创建! 就是说创建集合(数据表)后要再插入一个文档(记录)集合才会真正创建。 查看当前正在使用的数据库命令 dbMongoDB 中默认的数据库为 test如果你没有选择数据库集合将存放在 test 数据库中。 另外 数据库名可以是满足以下条件的任意UTF-8字符串: 不能是空字符串“”) 不得含有’ 空格)、.、$、/、\和\0 (空字符) 应全部小写 最多64字节 有一些数据库名是保留的可以直接访问这些有特殊作用的数据库: admin 从权限的角度来看这是root数据库。要是将一个用户添加到这个数据库这个用户自动继承所有数据库的权限。一些特 定的服务器端命令也只能从这个数据库运行比如列出所有的数据库或者关闭服务器。 local: 这个数据永远不会被复制可以用来存储限于本地单台服务器的任意集合 config: 当Mongo用于分片设置时config数据库在内部使用用于保存分片的相关信息。 b.2) 删除数据库 MongoDB 删除数据库的语法格式如下 db.dropDatabase()提示主要用来删除已经持久化的数据库 c) 集合操作 集合类似关系型数据库中的表。 可以显示的创建也可以隐式的创建。 c.1) 集合的显示创建 基本语法格式 db.createCollection(name)参数说明 name: 要创建的集合名称 例如创建一个名为 mycollection 的普通集合 db.createCollection(mycollection)查看当前库中的表show tables命令 show collections 或 show tablesc.2) 集合的隐式创建 当向一个集合中插入一个文档的时候如果集合不存在则会自动创建集合。 提示通常我们使用隐式创建文档即可。 c.3) 集合的删除 集合删除语法格式如下 db.collection.drop() 或 db.集合.drop()d) 文档基本CRUD 文档document的数据结构和 JSON 基本一样。 所有存储在集合中的数据都是 BSON 格式。 d.1) 文档的插入 (1) 单个文档的插入 使用insert() 或 save() 方法向集合中插入文档语法如下 db.collection.insert(document or array of documents,{writeConcern: document,ordered: boolean} )参数 document: 要插入到集合中的文档或文档数组。(json格式writeConcern: 性能可靠性的级别ordered是否排序 【示例】 要向comment的集合(表)中插入一条测试数据 db.comment.insert({articleid:100000,content:今天天气真好阳光明媚,userid:1001,nickname:Rose,createdatetime:new Date(),likenum:NumberInt(10),state:null})提示 1comment集合如果不存在则会隐式创建2mongo中的数字默认情况下是double类型如果要存整型必须使用函数NumberInt(整型数字)否则取出来就有问题了。3插入当前日期使用 new Date()4插入的数据没有指定 _id 会自动生成主键值5如果某字段没值可以赋值为null或不写该字段。 注意 1.文档中的键/值对是有序的。 2.文档中的值不仅可以是在双引号里面的字符串还可以是其他几种数据类型甚至可以是整个嵌入的文档)。 3.MongoDB区分类型和大小写。 4.MongoDB的文档不能有重复的键。 5.文档的键是字符串。除了少数例外情况键可以使用任意UTF-8字符 (2) 批量插入 语法 db.collection.insertMany([ document 1 , document 2, ... ],{writeConcern: document,ordered: boolean} )参数 【示例】 批量插入多条文章评论 db.comment.insertMany([ {_id:1,articleid:100001,content:我们不应该把清晨浪费在手机上健康很重要一杯温水幸福你我 他。,userid:1002,nickname:相忘于江湖,createdatetime:new Date(2019-08- 05T22:08:15.522Z),likenum:NumberInt(1000),state:1}, {_id:2,articleid:100001,content:我夏天空腹喝凉开水冬天喝温开水,userid:1005,nickname:伊人憔 悴,createdatetime:new Date(2019-08-05T23:58:51.485Z),likenum:NumberInt(888),state:1}, {_id:3,articleid:100001,content:我一直喝凉开水冬天夏天都喝。,userid:1004,nickname:杰克船 长,createdatetime:new Date(2019-08-06T01:05:06.321Z),likenum:NumberInt(666),state:1}, {_id:4,articleid:100001,content:专家说不能空腹吃饭影响健康。,userid:1003,nickname:凯 撒,createdatetime:new Date(2019-08-06T08:18:35.288Z),likenum:NumberInt(2000),state:1}, {_id:5,articleid:100001,content:研究表明刚烧开的水千万不能喝因为烫 嘴。,userid:1003,nickname:凯撒,createdatetime:new Date(2019-08- 06T11:01:02.521Z),likenum:NumberInt(3000),state:1} ]);提示 插入时指定了 _id 则主键就是该值。 如果某条数据插入失败将会终止插入但已经插入成功的数据不会回滚掉。 因为批量插入由于数据较多容易出现失败因此可以使用try catch进行异常捕捉处理测试的时候可以不处理。如了解 try { db.comment.insertMany([{_id:1,articleid:100001,content:我们不应该把清晨浪费在手机上健康很重要一杯温水幸福你我他。,userid:1002,nickname:相忘于江湖,createdatetime:new Date(2019-08-05T22:08:15.522Z),likenum:NumberInt(1000),state:1},{_id:2,articleid:100001,content:我夏天空腹喝凉开水冬天喝温开水,userid:1005,nickname:伊人憔悴,createdatetime:new Date(2019-08-05T23:58:51.485Z),likenum:NumberInt(888),state:1},{_id:3,articleid:100001,content:我一直喝凉开水冬天夏天都喝。,userid:1004,nickname:杰克船长,createdatetime:new Date(2019-08-06T01:05:06.321Z),likenum:NumberInt(666),state:1},{_id:4,articleid:100001,content:专家说不能空腹吃饭影响健康。,userid:1003,nickname:凯撒,createdatetime:new Date(2019-08-06T08:18:35.288Z),likenum:NumberInt(2000),state:1},{_id:5,articleid:100001,content:研究表明刚烧开的水千万不能喝因为烫嘴。,userid:1003,nickname:凯撒,createdatetime:new Date(2019-08-06T11:01:02.521Z),likenum:NumberInt(3000),state:1}]); } catch (e) {print (e); }d.2) 文档的基本查询 (1) 查询所有 查询数据的语法格式如下 db.collection.find(query, [projection])如果我想按一定条件来查询比如我想查询userid为1003的记录怎么办很简单只 要在find()中添加参数即可参数也是json格式如下 db.comment.find({userid:1003})如果你只需要返回符合条件的第一条数据我们可以使用findOne命令来实现语法和find一样。 如查询用户编号是1003的记录但只最多返回符合条件的第一条记录 db.comment.findOne({userid:1003})(2) 投影查询(Projection Query) 如果要查询结果返回部分字段则需要使用投影查询不显示所有字段只显示指定的字段。 如查询结果只显示 _id、userid、nickname : db.comment.find({userid:1003},{userid:1,nickname:1})默认 _id 会显示。 如查询结果只显示 userid、nickname 不显示 _id db.comment.find({userid:1003},{userid:1,nickname:1,_id:0})d.3) 文档的更新 更新文档的语法 db.collection.update(query, update, options)//或db.collection.update(query,update,{upsert: boolean,multi: boolean,writeConcern: document,collation: document,arrayFilters: [ filterdocument1, ... ],hint: document|string // Available starting in MongoDB 4.2} )【示例】 (1) 覆盖的修改 如果我们想修改_id为1的记录点赞量为1001输入以下语句 db.comment.update({_id:1},{likenum:NumberInt(1001)})执行后我们会发现这条文档除了likenum字段其它字段都不见了 (2) 局部的修改 为了解决这个问题我们需要使用修改器$set来实现命令如下 我们想修改_id为2的记录浏览量为889输入以下语句 db.comment.update({_id:2},{$set:{likenum:NumberInt(889)}})(3) 批量的修改 更新所有用户为 1003 的用户的昵称为 凯撒大帝 //默认只修改第一条数据 db.comment.update({userid:1003},{$set:{nickname:凯撒2}}) //修改所有符合条件的数据 db.comment.update({userid:1003},{$set:{nickname:凯撒大帝}},{multi:true})(4) 列值增长的修改 如果我们想实现对某列值在原有值的基础上进行增加或减少可以使用 $inc 运算符来实现。 需求对3号数据的点赞数每次递增1 db.comment.update({_id:3},{$inc:{likenum:NumberInt(1)}})d.4) 文档的删除 删除文档的语法结构 db.集合名称.remove(条件)以下语句可以将数据全部删除请慎用 db.comment.remove({})如果删除_id1的记录输入以下语句 db.comment.remove({_id:1})e) 文档的分页查询 e.1) 统计查询 统计查询使用count()方法语法如下 db.collection.count(query, options)【示例】 (1) 统计所有记录数 统计comment集合的所有的记录数 db.comment.count()(2) 按条件统计记录数 例如统计userid为1003的记录条数 db.comment.count({userid:1003})默认情况下 count() 方法返回符合条件的全部记录条数。 e.2) 分页列表查询 可以使用limit()方法来读取指定数量的数据使用skip()方法来跳过指定数量的数据 基本语法如下所示 db.COLLECTION_NAME.find().limit(NUMBER).skip(NUMBER)如果你想返回指定条数的记录可以在find方法后调用limit来返回结果(TopN)默认值20例如 db.comment.find().limit(3)skip方法同样接受一个数字参数作为跳过的记录条数。前N个不要,默认值是0 db.comment.find().skip(3)e.3) 排序查询 sort() 方法对数据进行排序sort() 方法可以通过参数指定排序的字段并使用 1 和 -1 来指定排序的方式其中 1 为升序排列而 -1 是用于降序排列。 语法如下所示 db.COLLECTION_NAME.find().sort({KEY:1}) 或 db.集合名称.find().sort(排序方式)例如 对userid降序排列并对访问量进行升序排列 db.comment.find().sort({userid:-1,likenum:1})skip(), limilt(), sort()三个放在一起执行的时候执行的顺序是先 sort(), 然后是 skip()最后是显示的 limit()和命令编写顺序无关 f) 文档的更多查询 f.1) 正则的复杂条件查询 MongoDB的模糊查询是通过正则表达式的方式实现的。格式为 db.collection.find({field:/正则表达式/}) 或 db.集合.find({字段:/正则表达式/})提示正则表达式是js的语法直接量的写法。 例如我要查询评论内容包含“开水”的所有文档代码如下 db.comment.find({content:/开水/})如果要查询评论的内容中以“专家”开头的代码如下 db.comment.find({content:/^专家/})f.2) 比较查询 , , , 这个操作符也是很常用的格式如下: db.集合名称.find({ field : { $gt: value }}) // 大于: field value db.集合名称.find({ field : { $lt: value }}) // 小于: field value db.集合名称.find({ field : { $gte: value }}) // 大于等于: field value db.集合名称.find({ field : { $lte: value }}) // 小于等于: field value db.集合名称.find({ field : { $ne: value }}) // 不等于: field ! value示例查询评论点赞数量大于700的记录 db.comment.find({likenum:{$gt:NumberInt(700)}})f.3) 包含查询 包含使用$in操作符。 示例查询评论的集合中userid字段包含1003或1004的文档 db.comment.find({userid:{$in:[1003,1004]}})不包含使用$nin操作符。 示例查询评论集合中userid字段不包含1003和1004的文档 db.comment.find({userid:{$nin:[1003,1004]}})f.4) 条件连接查询 我们如果需要查询同时满足两个以上条件需要使用$and操作符将条件进行关联。相 当于SQL的and 格式为 $and:[ { },{ },{ } ]示例查询评论集合中likenum大于等于700 并且小于2000的文档 db.comment.find({$and:[{likenum:{$gte:NumberInt(700)}},{likenum:{$lt:NumberInt(2000)}}]})如果两个以上条件之间是或者的关系我们使用 操作符进行关联与前面 and的使用方式相同 格式为 $or:[ { },{ },{ } ]示例查询评论集合中userid为1003或者点赞数小于1000的文档记录 db.comment.find({$or:[ {userid:1003} ,{likenum:{$lt:1000} }]})g) 常用命令总结 选择切换数据库use articledb 插入数据db.comment.insert({bson数据}) 查询所有数据db.comment.find(); 条件查询数据db.comment.find({条件}) 查询符合条件的第一条记录db.comment.findOne({条件}) 查询符合条件的前几条记录db.comment.find({条件}).limit(条数) 查询符合条件的跳过的记录db.comment.find({条件}).skip(条数) 修改数据db.comment.update({条件},{修改后的数据}) 或db.comment.update({条件},{$set:{要修改部分的字段:数据}) 修改数据并自增某字段值db.comment.update({条件},{$inc:{自增的字段:步进值}}) 删除数据db.comment.remove({条件}) 统计查询db.comment.count({条件}) 模糊查询db.comment.find({字段名:/正则表达式/}) 条件比较运算db.comment.find({字段名:{$gt:值}}) 包含查询db.comment.find({字段名:{$in:[值1值2]}})或db.comment.find({字段名:{$nin:[值1值2]}}) 条件连接查询db.comment.find({$and:[{条件1},{条件2}]})或db.comment.find({$or:[{条件1},{条件2}]})
http://www.hkea.cn/news/14332960/

相关文章:

  • 网上推广引流的有用吗?西安seo培训哪个好
  • 网站三站合一朋友做网站网站挣了好多钱
  • 鲜花店网站建设项目三的设计与制作
  • 娱乐类网站怎么建设网页项目策划书模板
  • 大型网站开发框架seo的定义
  • 找哪里做网站太湖县住房与建设局网站
  • 网站建设123课工场网站建设培训
  • 天河门户网站建设公司哈尔滨信息工程学院
  • 做网站包括什么条件企业所得税政策最新2023税率
  • app推广服务部济南网站优化多少钱
  • 高端大气的网站模板国外的旅游网站开发
  • 广州 创意的网站设计银川网站建设是什么
  • 上海建设工程信息网站兰州网站建设开发
  • 电商类网站有哪些兰州app外包
  • 做网站网站要找谁本地app开发公司电话
  • 沧州网站建设优化公司石家庄又封了
  • 广州积分入学网站制作相册模板免费的
  • 做网站网课西安网站seo
  • 深圳微商城网站制作价格网站建设方案规划书
  • 个人网站设计及实现雷神代刷网站推广快速
  • 河南网站建设服务公司郑州建设工程交易中心网站
  • 设计人才网站广州做网站新锐
  • 郑州购物网站建设怎么写app程序
  • 能买源码的网站有哪些好看的官网源码
  • 58企业网站如何做网站开发ppt
  • 电商网站的活动怎么做宣传片拍摄方案怎么写
  • 快速优化网站排名的方法wordpress中home page
  • 网站模板建站教程视频教程重庆天古装饰公司
  • 山东网站建设培训简洁大气企业网站
  • 蛋糕店网站建设方案网络公司注册的流程