MongoDB实用技巧分享:导入文件夹 集合添加删除字段 模糊查询

MongoDB导入文件夹:

扔给你一堆数据,会不会让你一脸懵逼?

来教你通过文件夹和命令导入数据。

首先可以选择使用mongo命令将数据库删除:

use db_name;
db.dropDatabase()

导入(指定文件夹)数据:

linux命令:mongorestore -d db_name 文件夹目录
windows命令:mongorestore.exe -d db_name 文件夹目录


领导让你给某集合(表)添加一个新字段:

MongoDB 使用 update() 和 save() 方法来更新集合中的文档

参数说明:

  • query : update的查询条件,类似sql update查询内where后面的。
  • update : update的对象和一些更新的操作符(如$,$inc...)等,也可以理解为sql update查询内set后面的
  • upsert : 可选,这个参数的意思是,如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。
  • multi : 可选,mongodb 默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。
  • writeConcern :可选,抛出异常的级别。

 

1 、添加一个字段.  table 代表表名 , 添加字段 content,字符串类型。

  db.table.update({}, {$set: {content:""}}, {multi: true})

2、删除一个字段

  db.table.update({},{$unset:{content:""}},false, true)



模糊查询:


MongoDB查询条件可以使用正则表达式,从而实现模糊查询的功能。模糊 查询可以使用$regex操作符或直接使用正则表达式对象。
MySQLMongoDB
select * from student where  name like ’%joe%’
db.student.find( {name: {$regex:/joe/}})
select * from student where  name regexp ’joe’
db.student.find( {name:/joe/})

$regex操作符的介绍
MongoDB使用$regex操作符来设置匹配字符串的正则表达式,使用 PCRE(Pert Compatible Regular Expression)作为正则表达式语言。
  • regex操作符
    • {<field>:{$regex:/pattern/,$options:’<options>’}}
    • {<field>:{$regex:’pattern’,$options:’<options>’}}
    • {<field>:{$regex:/pattern/<options>}}
  • 正则表达式对象
    • {<field>: /pattern/<options>}
$regex与正则表达式对象的区别:
  • 在$in操作符中只能使用正则表达式对象,例如:{name:{$in:[/^joe/i,/^jack/}}
  • 在使用隐式的$and操作符中,只能使用$regex,例如:{name:{$regex:/^jo/i, $nin:['john']}}
  • 当option选项中包含X或S选项时,只能使用$regex,例如:{name:{$regex:/m.*line/,$options:"si"}}

$regex操作符的使用
$regex操作符中的option选项可以改变正则匹配的默认行为,它包括 i, m, x以及S四个选项,其含义如下
  • i 忽略大小写,{<field>{$regex/pattern/i}},设置i选项后,模式中的字母会进行大小写不敏感匹配。
  • m 多行匹配模式,{<field>{$regex/pattern/,$options:'m'},m选项会更改^和$元字符的默认行为,分别使用与行的开头和结尾匹配,而不是与输入字符串的开头和结尾匹配。
  • x 忽略非转义的空白字符,{<field>:{$regex:/pattern/,$options:'m'},设置x选项后,正则表达式中的非转义的空白字符将被忽略,同时井号(#)被解释为注释的开头注,只能显式位于option选项中。
  • s 单行匹配模式{<field>:{$regex:/pattern/,$options:'s'},设置s选项后,会改变模式中的点号(.)元字符的默认行为,它会匹配所有字符,包括换行符(\n),只能显式位于option选项中。
使用$regex操作符时,需要注意下面几个问题:
  • i,m,x,s可以组合使用,例如:{name:{$regex:/j*k/,$options:"si"}}
  • 在设置索弓}的字段上进行正则匹配可以提高查询速度,而且当正则表达式使用的是前缀表达式时,查询速度会进一步提高,例如:{name:{$regex: /^joe/}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值