mongo基础---增删改查

正文

MongoDB 是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。MongoDB是一个介于关系型数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。他支持的数据结构非常松散,是类似Json格式,因此可以存储比较复杂的数据类型。Mongo最大的特点是他支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引----【来源百度百科】

一、Mongo的查询语句

公式:

db.collection.find({query filter},{projection})

解释:

  • query filter:查询的条件,类似于MySql中的where语句;可多选
  • projection:列出要查询的数据,可选值为1、0;其中1表示展示,0表示不展示;其中_id属性默认是展示;可多选
  • collection:表示要查询的集合(本文所有例子中默认为app集合)

例子:

  • 查询所有:db.app.find({})
  • 部分查询:db.app.find({_id:3})
  • 键的筛选:db.app.find({},{name:1,_id:0})

说明:

建的筛选是查询时至返回自己感兴趣的键值,通过指定projection来实现。可以节省传输的数据量,又能节省客户端解码文档的时间和内存消耗。

查询条件:

  • 比较查询:通过$lt,$lte,$gt,$gte,$ne来实现,分别对应<,<=,>,>=,!=;它们可以组合起来以查找一个范围内的值
  • 关联查询:通过$in,$nin,$or实现,分别对应在某一个集合中、不在某一个集合中(此处集合与collection集合不同,可以理解成一个键的多个值所组成的数学形式上的集合)以及或逻辑

例子:

  • 查询_id键在20与60之间:db.app.find({_id:{$gt:20,$lt:60}})
  • 查询_id键不为16的所有数据:db.app.find({_id:{$ne:16}})
  • 查询_id键在[1,3,6,7]中的数据:db.app.find({_id:{$in:[1,3,6,7]}})
  • 查询_id键为16或者name为讯飞输入法的数据:db.app.find({$or:[{_id:16},{name:"讯飞输入法"}]})

特殊类型的查询:

  • 查询null:db.app.find({name:{$in:[null]}});查询所有name为null的数据或者name不存在的数据
  • 正则查询:mongo不直接支持模糊查询,但是可以通过正则表达式去实现模糊查询,例如:查询所有app的name以讯飞开头的所有数据:db.app.find({name:/^讯飞/})
  • 内嵌查询:如某个键并不是一个基础的类型,而是一个嵌套的类型,则可以使用内嵌查询,来满足业务需求;例如name键中包含first与last两个子健,要查询所有name中first为讯飞的数据,可以:db.app.find({name.first:"讯飞"})
  • 数组查询:通过$all,$size,$slice实现;分别表示返回满足所有数组元素的数据、满足指定长度的数据以及数组的一个子集合
    • db.app.find({tagIds:{$all:[1,2]}}),只要某数据中tagIds键包含[1,2]数组,就返回
    • db.app.find({tagIds:{$size:3}}),只要某数据中tagIds键中有有三个值,就返回
    • db.app.find({tagIds:{$slice:[1,2]}}),返回偏移量为1,元素个数为2

$where查询:

暂时不会,看某些参考博客上说,这种查询方式不会利用到索引,查询效率较低,不宜使用

limit,skip和sort的使用

limit:限制结果数量,限制的是上限。
skip:略过匹配到的前n个文档,然后返回余下的文档。skip略过过多的文档时会产生性能问题,建议尽量避免。
sort:按照指定的键对文档进行排序,1为升序,-1为降序。

db.app.find({}).limit(20).sort({updatetime:-1})

游标

mongo查询结果其实一个游标,可以通过var cursor = db.app.find({})来获取,可以利用游标来获取结果,也可以达到limit、skip等效果

二、Mongo的update语句

公式:

db.collection.update({update filter},{update key-value},{upsert|multi|writeConcern})

解释:

  • update filter:update的查询条件,与find中query filter差不多
  • update key-value:要更新的update对象
  • upsert:如果不存在update的数据,是否插入新的数据,默认是false,不插入;可选参数
  • multi:默认false。只更新找到的第一条记录;true,更具条件更新全部数据
  • writeConcern:抛出异常级别---没用过

例子:

  • db.app.update({_id:3},{name:"讯飞输入法"});将id等与3的数据更新为{"_id":3,"name":"讯飞输入法"},也即该方法会删除那些没有在update key-value中的出现的键(由于mongo没有回滚机制,个人感觉这个语法很坑)
  • db.app.update({_id:3},{$set:{name:"讯飞输入法"}});将id等于3的数据中键name的值更新为讯飞输入法

针对于update key-value说明:

  • $set:用来指定一个键并更新键值,若键不存在并创建
  • $inc:对文档的某个值为数字型(只能为满足要求的数字)的键进行增减的操作
  • $unset:主要是用来删除键
  • $push:向文档的某个数组类型的键添加一个数组元素,不过滤重复的数据。添加时键存在,要求键值类型必须是数组;键不存在,则创建数组类型的键
  • $pop:从数组的头或者尾删除数组中的元素,从数组尾部删除:1,从数组头部删除:-1
  • ....

三、Mongo的remove语句

公式:

db.collection.remove({remove filter},{justOne|writeConcern})

解释:

  • remove filter:remove的查询条件,与find中的query filter差不多
  • justOne:为1表示删除一个元素
  • writeConcern:抛出异常级别

列子:

db.app.remove({name:"/^讯飞/"},{justOne:1})

四、Mongo的insert/save语句

公式:

  • db.collection.insert(document)
  • db.collection.save(document)

解释:

document表示要插入的文档

例子:

  • db.app.insert({name:"讯飞输入法",tagIds:[1,2,3,4]})
  • db.app.save({name:"讯飞输入法",tagIds:[1,2,3,4]})

区别:

当主键"_id"不存在时,都是添加一个新的文档,但主健"_id"存在时,就有些不同了;insert:当主键"_id"在集合中存在时,不做任何处理。save:当主键"_id"在集合中存在时,进行更新。

时间: 2024-11-05 12:57:34

mongo基础---增删改查的相关文章

Linq基础增删改查

使用Linq时要注意一下问题:1.创建Linq连接后生成的dbml文件不要变动,生成的表不要碰,拖动表也会造成数据库连接发生变动,需要重新保存.2.属性拓展的使用:添加一个新的类,不要在dbml中添加属性拓展,一旦数据库变动,属性拓展类就会失效.3.使用Linq获取的数据都是?int,?string等?数据类型,意思是也有可能为空,这时候操作数据需要先把数据类型转化成int,string等数据类型. 在这里操作数据库用到了lambda表达式,是一种匿名函数,使用lambda表达式自动带有防攻击,

1MySQL语法基础--增删改查

建表语句 2 CREATE TABLE `students`('id'INT NOT NULL AUTO_INCREMENT,`name`VARCHAR(200)NOT NULL); 3 4 USE `school`; 5 6 CREATE TABLE `students`( 7 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY, 8 `name` VARCHAR(20) NOT NULL, 9 `nickname` VARCHAR(20) NULL, 1

2017-6-1 Linq 基础查询 (增删改查)

用小型人员管理系统的项目实战来练习linq的基础增删改查: using System; using System.Collections.Generic; using System.Linq; using System.Web; /// <summary> /// users 的摘要说明 /// </summary> public partial class users { public string sexstr { get { return Convert.ToBoolean(

BootstrapTable+KnockoutJS实现增删改查解决方案

BootstrapTable+KnockoutJS实现增删改查解决方案 前言:上篇介绍了下ko增删改查的封装,确实节省了大量的js代码.博主是一个喜欢偷懒的人,总觉得这些基础的增删改查效果能不能通过一个什么工具直接生成页面效果,啥代码都不用写了,那该多爽.于是研究了下T4的语法,虽然没有完全掌握,但是算是有了一个大致的了解.于是乎有了今天的这篇文章:通过T4模板快速生成页面. KnockoutJS系列文章: JS组件系列——BootstrapTable+KnockoutJS实现增删改查解决方案(

BootstrapTable+KnockoutJS自定义T4模板快速生成增删改查页面

前言:上篇介绍了下ko增删改查的封装,确实节省了大量的js代码.博主是一个喜欢偷懒的人,总觉得这些基础的增删改查效果能不能通过一个什么工具直接生成页面效果,啥代码都不用写了,那该多爽.于是研究了下T4的语法,虽然没有完全掌握,但是算是有了一个大致的了解.于是乎有了今天的这篇文章:通过T4模板快速生成页面. KnockoutJS系列文章: JS组件系列——BootstrapTable+KnockoutJS实现增删改查解决方案(一) JS组件系列——BootstrapTable+KnockoutJS

.net xml 增删改查基础复习及干货分享

今天做做项目时,有一个需求需要用到一些固定的文本数据,觉得将这些需要存储的信息直接写在代码里很不友好,放在数据库中存储又觉得不够方便,自然就想到了使用xml来进行操作,我平常在项目中其实用到xml的机会并不多,今天既然碰到了,就再温故知新一下吧.... xml简述 xml被设计用来传输和存储数据.(html被设计用来显示数据) xml指可扩展标记语言(Extensible Markup Language) xml是一种标记语言,很类似html xml的设计宗旨是传输数据,而非显示数据 xml标签

[Android] SQLite数据库之增删改查基础操作

    在编程中常常会遇到数据库的操作,而Android系统内置了SQLite,它是一款轻型数据库,遵守事务ACID的关系型数据库管理系统,它占用的资源非常低,可以支持Windows/Linux/Unix等主流操作系统,同一时候可以跟非常多程序语言如C#.PHP.Java等相结合.以下先回想SQL的基本语句,再讲述Android的基本操作. 一. adb shell回想SQL语句     首先,我感觉自己整个大学印象最深的几门课就包含<数据库>,所以想先回想SQL增删改查的基本语句.而在And

基础的增删改查,数据库优化,索引

mysql的特点 关系型数据库,免费使用, 插入式存储引擎, 性能高, 基础的增删改查 ddl语句,数据定义语句 123456789101112 create database test1;drop database test1;use test1;create table emp(ename varchar(10),hiredate date,sal decimal(10,2),deptno int(2));drop table emp;alter table emp modify ename

week_one-python基础 列表 增删改查

# Author:larlly'''#列表增删改查#定义列表name = ["wo","ni","ta","wo"] #定义列表num_list = list(range(1,10)) #range生成范围的数,强制转化为列表#查print(num_list)print(name[0])print(name[0:2]) #顾头不顾尾print(name[-1])print(name[:]) #取所有值print(name[-3