热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

c#mongodbor查询_6、MongoDB基本使用

MongodbMongodb优势基础命令管理备份恢复数据库命令集合命令存储的数据数据查询数据增加数据更新数据删除高级查询比较运算符范围运算符或者正则表达式常用方法自定义查询返回指定

Mongodb

Mongodb优势

基础命令

管理

备份

恢复

数据库命令

集合命令

存储的数据

数据查询

数据增加

数据更新

数据删除

高级查询

比较运算符

范围运算符

或者

正则表达式

常用方法

自定义查询

返回指定的字段

排序

统计

去重

索引

创建索引

单利索引

联合索引

删除索引

查看索引

Python操作Mongodb

Mongodb

MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统。在高负载的情况下,添加更多的节点,可以保证服务器性能。MongoDB 旨在为WEB应用提供可扩展的高性能数据存储解决方案。MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成。MongoDB 文档类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组,它是一种非关系的数据库Nosql。

那么非关系带来的一个问题就是,耗存储空间,就比如10000条数据,每条数据都有一条是一样的,那么在关系型数据库的情况下,我们就可以直接使用外键的方式来进行存储,那么对于mongodb这样的非关系型数据库就需要每一条数据都进行存储,带来一定的资源浪费;

在关系型数据库下,扩展性比较差,如果我们开始定义了一些数据,后期想要改起来非常麻烦,而且在大数据下IO比较大,因为我们要查询一条数据出来可能需要连很多表才能把这个数据给完整展现出来。那对Mongodb来说,它解决这个问题就非常简单,因为它是菲关系的,数据和数据之间没有任何关联,不涉及到连表查询,同时打来的好处就是速度快,灵活性比较好,不需要预先为表做字段,直接插即可;

97ad8a1dc79c877aa6da44d36d916c34.png

Mongodb优势

易扩展性:NoSQL数据库种类繁多,但是一个共同的特点就是去掉关系型数据库的关系特性,数据之间无关系,这样就非常易于扩展;

性能高:在大数据量的情况下表现优秀,NoSQL数据库都具有非常搞的读写性能,尤其是在大数据量下,这得益于它的无关系性,数据库结构简单;

灵活性:NoSQL无需事先为要存储的数据建立字段,随时可以存储自定义的数据格式,而在关系型数据库里,增删字段是一见非常麻烦的事情;

基础命令

管理

管理包含数据备份和恢复;

备份

mongodump -h dbHost -d dbName -o backupDir

恢复

mongorestore -h dbHost -d dbName --dir backupDir

数据库命令

show dbs:查看库;

use:切换数据库;

db:查看当前数据库;

db.dropDatabase():删除当前数据库;

集合命令

show collections:查看当前数据库的所有集合;

db.集合名称.drop():删除集合;

db.createCollection("cce"):创建一个集合;

存储的数据

Object ID:文档ID;

每个文档都有一个_id,保证文档的唯一性,如果没有显示定义,那么mongodb会自动生成;

Sting:字符串,必须是有效的utf8;

Boolean:存储一个布尔类型,true或false;

Integer:整形可以是32位或者64位;

Double:存储浮点数;

Arrays:数组或者列表,多个值存储到一个文档;

Object:用于嵌入式的文档,即一个值为一个文档;

Null:存储null值;

Timestamp:时间戳;

Date:存储当前时间或者时间的unix格式;

创建日期的语句:new Date('2018-01-15') # 需要传入一个时间;

数据查询

db.集合名称.find():查找指定的数据,如果没有给定查询条件,默认查询所有, db.caichangen.find({"age":18})这是一个给定条件的示例;

数据增加

db.caichangen.insert({"name":"cce","age":18}) # 增加一条数据{"name":"cce","age":18}) # 如果数据已存在那么会抛出错误;

db.caichangen.save({"name":"cce","age":18}) # 增加一条数据{"name":"cce","age":18}) # 如果已存在就更新,如果不存在那么就插入;

数据更新

语法:db.集合名称.update(,,{multi:})

更新一条数据:db.caichangen.update({},{age:30}) | db.caichangen.update({},{$set:{age:30}})

条件更新:db.caichangen.update({age:20},{age:30})

批量更新:db.caichangen.update({age:20},{$set:{age:30}},{multi:true})

数据删除

语法:db.集合名称.remove(,{justOne:})

query:查询条件;

justOne:布尔值,为true删除一条,默认false删除所有数据;

删除匹配条件的所有:db.caichangen.remove({age:30},{justOne:false})

高级查询

find:查询,可以在后面加上pretty()将结果格式化;

findOne:查询,返回第一个集合,可以在后面加上pretty()将结果格式化;

比较运算符

等于:默认是等于判断,没有运算符;

$lt:小于;

$lte:小于等于;

$gt:大于;

$gte:大于等于;

$ne:不等于;

语法:db.caichangen.find({age:{$lt:18}})

范围运算符

$in:是否在某个范围内;

$nin:是否在某个范围内;

语法:db.caichangen.find({age:{$in:[18,19]}})

或者

and:并且;

$or:值为数组,数组中每个元素为json;

语法:db.caichangen.find({$or:[{age:18},{name:"cce"}]})

查询姓名为cce或者cfj并且年龄是18的:db.caichangen.find({$or:[{name:"cfj"},{name:"cce"}],age:18})

正则表达式

使用//或者$regex编写正则表达式;

语法:

db.caichangen.find({name:/^c/})

db.caichangen.find({name:{$regex:'e$'}})

常用方法

limit:限制返回指定数量的文档;

db.caichangen.find().limit(Number)

skip:用于跳过指定数量的文档;

db.caichangen.find().skip(Number)

同时使用:

db.caichangen.find().limit(Number).skip(Number)

自定义查询

使用$where后面写一个函数,返回满足条件的数据;

示例:

db.caichangen.find({$where:function(){return this.age>30;}})

返回指定的字段

语法:db.集合名称.find({},{字段:0/1}) # 0不显示,1显示;

示例:

db.caichangen.find({name:{$regex:'e$'}},{age:1,_id:0})

排序

sort:sort可以在返回结果集后进行排除处理,传入一个1或者-1,1升序,-1降序;

示例:

db.caichangen.find().sort({age:1})

统计

count:可以对结果集进行统计,也可以直接统计集合;

示例:

db.caichangen.find().count()

db.caichangen.count({age:{$gt:20}})

去重

distinct:可以对结果集进行去重;

语法:

db.集合名称.distinct('去重字段':{条件})

示例:

db.stu.distinct('age':{age:{$gt:18}})

索引

建立索引提升查询速度,默认情况下mongodb会自动将_id字段设置为索引;

创建索引

单利索引

测试:插入10万条数据到数据库中

for(var i&#61;0;i<100000;i&#43;&#43;){db.caichangen.insert({name:"cce"&#43;i,age:i})}

测试&#xff1a;

db.caichangen.find({&#39;name&#39;:&#39;cce10000&#39;}) # 测试查询

db.caichangen.find({&#39;name&#39;:&#39;cce10000&#39;}).explain(&#39;executionStats&#39;) # 查看上面查询语句的执行状态信息&#xff0c;executionTimeMillis是查询时间&#xff1b;

创建索引&#xff1a;

语法&#xff1a;db.集合名称.ensureIndex({属性:1/-1}) # 1表示升序&#xff0c;-1表示降序&#xff0c;-1的使用场景是经常使用sort来操作数据&#xff1b;

示例&#xff1a;db.caichangen.ensureIndex({name:1})

联合索引

语法&#xff1a;db.集合名称.ensureIndex({属性:1/-1,属性:1/-1})

删除索引

语法&#xff1a;db.集合名称.dropIndex(&#39;索引名称&#39;)

查看索引

语法&#xff1a;db.集合名称.getIndexs()

Python操作Mongodb

安装&#xff1a;pip install pymongo

from pymongo import MongoClient

client &#61; MongoClient(host&#61;&#39;192.168.1.254&#39;, port&#61;27017) # 初始化一个client对象&#xff0c;拿到一个连接初始化信息

collection &#61; client[&#39;cce&#39;][&#39;caichangen&#39;] # 指定要连接的库和集合

# 清空数据库

collection.drop()

# 插入单条数据

date &#61; {"_id": 1, "name": "cce0", "age": 100}

collection.insert(date)

# 插入多条数据

data_many&#61;[{"name": "name" &#43; str(1000&#43;i), &#39;age&#39;: i} for i in range(10)] # 创建数据

collection.insert_many(data_many) # 多条插入

# 查询所有数据

result&#61;collection.find({&#39;name&#39;:&#39;cce0&#39;}) # 返回一个游标对象&#xff0c;它是一个可迭代对象&#xff0c;当游标走到最后的时候那么就获取不到数据了&#xff0c;和我们的生成器一样&#xff1b;

for i in result:

print(i)

# 查询一条数据

result&#61;collection.find_one({&#39;name&#39;:&#39;cce0&#39;})

print(i)

# 更新一条数据

collection.update_one({&#39;name&#39;:&#39;cce0&#39;},{"$set":{&#39;name&#39;:&#39;caichangen&#39;}})

# 更新所有数据

collection.update_many({&#39;name&#39;:&#39;cce0&#39;},{"$set":{&#39;name&#39;:&#39;caichangen&#39;}})



推荐阅读
  • 包含phppdoerrorcode的词条 ... [详细]
  • 如何在Java中使用DButils类
    这期内容当中小编将会给大家带来有关如何在Java中使用DButils类,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。D ... [详细]
  • 您的数据库配置是否安全?DBSAT工具助您一臂之力!
    本文探讨了Oracle提供的免费工具DBSAT,该工具能够有效协助用户检测和优化数据库配置的安全性。通过全面的分析和报告,DBSAT帮助用户识别潜在的安全漏洞,并提供针对性的改进建议,确保数据库系统的稳定性和安全性。 ... [详细]
  • 在Linux系统中避免安装MySQL的简易指南
    在Linux系统中避免安装MySQL的简易指南 ... [详细]
  • DVWA学习笔记系列:深入理解CSRF攻击机制
    DVWA学习笔记系列:深入理解CSRF攻击机制 ... [详细]
  • 基于Net Core 3.0与Web API的前后端分离开发:Vue.js在前端的应用
    本文介绍了如何使用Net Core 3.0和Web API进行前后端分离开发,并重点探讨了Vue.js在前端的应用。后端采用MySQL数据库和EF Core框架进行数据操作,开发环境为Windows 10和Visual Studio 2019,MySQL服务器版本为8.0.16。文章详细描述了API项目的创建过程、启动步骤以及必要的插件安装,为开发者提供了一套完整的开发指南。 ... [详细]
  • 在《Linux高性能服务器编程》一书中,第3.2节深入探讨了TCP报头的结构与功能。TCP报头是每个TCP数据段中不可或缺的部分,它不仅包含了源端口和目的端口的信息,还负责管理TCP连接的状态和控制。本节内容详尽地解析了TCP报头的各项字段及其作用,为读者提供了深入理解TCP协议的基础。 ... [详细]
  • Oracle字符集详解:图表解析与中文乱码解决方案
    本文详细解析了 Oracle 数据库中的字符集机制,通过图表展示了不同字符集之间的转换过程,并针对中文乱码问题提供了有效的解决方案。文章深入探讨了字符集配置、数据迁移和兼容性问题,为数据库管理员和开发人员提供了实用的参考和指导。 ... [详细]
  • 尽管我们尽最大努力,任何软件开发过程中都难免会出现缺陷。为了更有效地提升对支持部门的协助与支撑,本文探讨了多种策略和最佳实践,旨在通过改进沟通、增强培训和支持流程来减少这些缺陷的影响,并提高整体服务质量和客户满意度。 ... [详细]
  • C#微信开发入门教程第二篇:新手快速上手指南,含详细视频讲解
    在距离上次课程一个多星期后,我们终于带来了第二讲的内容。虽然原计划是一周一次更新,但由于工作繁忙有所延迟。近期在交流群中发现,一些初学者已经能够熟练调用微信接口,但对微信公众平台的消息接收处理机制还不够了解。因此,本次课程将详细介绍如何高效处理微信公众平台的消息接收,并提供详细的视频讲解,帮助大家快速上手。 ... [详细]
  • 在CentOS上部署和配置FreeSWITCH
    在CentOS系统上部署和配置FreeSWITCH的过程涉及多个步骤。本文详细介绍了从源代码安装FreeSWITCH的方法,包括必要的依赖项安装、编译和配置过程。此外,还提供了常见的配置选项和故障排除技巧,帮助用户顺利完成部署并确保系统的稳定运行。 ... [详细]
  • MySQL:不仅仅是数据库那么简单
    MySQL不仅是一款高效、可靠的数据库管理系统,它还具备丰富的功能和扩展性,支持多种存储引擎,适用于各种应用场景。从简单的网站开发到复杂的企业级应用,MySQL都能提供强大的数据管理和优化能力,满足不同用户的需求。其开源特性也促进了社区的活跃发展,为技术进步提供了持续动力。 ... [详细]
  • MySQL 数据操作:增、删、查、改全面解析
    MySQL 数据操作:增、删、查、改全面解析 ... [详细]
  • NoSQL数据库,即非关系型数据库,有时也被称作Not Only SQL,是一种区别于传统关系型数据库的管理系统。这类数据库设计用于处理大规模、高并发的数据存储与查询需求,特别适用于需要快速读写大量非结构化或半结构化数据的应用场景。NoSQL数据库通过牺牲部分一致性来换取更高的可扩展性和性能,支持分布式部署,能够有效应对互联网时代的海量数据挑战。 ... [详细]
  • MySQL 8.0 中的二进制日志格式详细解析及其官方文档参考。本文介绍了MySQL服务器如何使用不同的日志记录格式来记录二进制日志,包括早期版本中基于SQL语句的复制机制(即基于语句的日志记录)。此外,还探讨了其他日志记录方式,如基于行的日志记录和混合日志记录模式,并提供了配置和管理这些日志格式的最佳实践。 ... [详细]
author-avatar
ndo2205188
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有