Python全栈 MongoDB 数据库(数据的查找)

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
云原生数据库 PolarDB PostgreSQL 版,标准版 2核4GB 50GB
云原生数据库 PolarDB MySQL 版,通用型 2核8GB 50GB
简介: Python全栈 MongoDB 数据库、MongoDB 数据库查找


非关系型数据库和关系型数据库的区别?
不是以关系模型构建的,结构自由
非关系型数据库不保证数据一致性
非关系型数据库可以在处理高并发和海量数据时弥补关系数据库的不足
非关系型数据库在技术上没有关系型数据库技术成熟

查找操作:
db.集合名.find(查找条件,域)
查找条件:
    键值对的形式给出要展示的文档
域:
以键值对对的形式给出要展示或不展示的域
0为值不显示该域 1为值显示该域
如果使用0设置某些域不显示默认其他域显示
如果使用1设置某些域显示默认其他域不显示
*_id 只有设置为0才不显示否则默认显示
除_id以外,其他域必须同时设置0或1

db.集合名.findOne(查找条件,域)
查找复合条件的第一条文档
查找条件(query):
操作符:
使用$注明的一特殊意义的字符串,表达某个特定含义
比如:$gt表示大于
语法:
db.集合名.find({name:{$gt:"tom"}}, {_id:0})
比较操作符:
$eq 等于
$lt         小于(字符串也可以比较大小)
$lte        小于等于
$gt        大于
$gte         大于等于
$ne        不等于
$in          在什么里(in)
$nin        不在什么里(not in)
逻辑操作符:
$and    与
query内如果多个条件用逗号隔开默认就是and关系
$or       或
$not     非
$nor     既不也不
数组:
使用中括号[]将一定的数据组织为一种数据结构
数组中的数据类型可以不同  是有序的
db.class2.find({score:{$gt:90}}, {_id:0})
$size
    通过数组中个数查找
$all
    查找数组中包含多项的
$slice
取数组中部分显示,在域(field)中声明
其他query查询:
$exists
判断一个域是否存在
$mod
余数查找
$type
数据类型查找
distinct()
db.class2.distinct("score")
    查看集合内某个域的取值范围
pretty()
将查询结果格式化显示
limit(n)
显示查找结果的前n条结果
skip(2)
跳过前条显示后面的结果 
count()
计数统计
sort({filed:1/-1})
排序
参数:键代表那个域,1表示升序, -1表示降序
复合排序: 当第一排序项相同的时候按照第二排序项排序,以此类推

函数的连续调用
当一个函数的返回结果仍然是文档集合的时候可以连续调用函数

文档的删除操作

       db.集合名.remove(query,justOne)
remove(query,justOne)
功能 : 删除文档
参数 : query
筛选要删除的文档,相当于where
                        用法同 查找
justOne
布尔值  
             默认为False 表示删除所有复合条件的文档
                          如果设置为true 则表示只删除第一条复合条件文档


修改操作:
db.集合名.update(query, update,upert,multi)
参数:
query:
筛选要查找要修改的文档
update:
将筛选的文档修改为什么内容
需要配合修改操作符
upsert:
bool值  默认false  如果query的文档不存在则不进行任何操作
设置为true 如果query和文档不存在 就根据query和update插入新文档
multi:
bool值  默认false 如果query文档有多条则只修改第一条
设置为true 则修改所有符合条件的文档、




综合示例:

1. 创建数据库 名字 grade

use grade

2. 数据库中创建集合 名字  class
3. 集合中插入若干文档格式如下

{name:'zhang',age:10,sex:'m',hobby:['a','b'...]}

年龄在4-13之间
hobby几项都可以,可选项: draw  sing  dance  basketball  football  pingpong  running  computer 

db.class.insert({name:'zhang',age:10,sex:'m',hobby:['a','b'...]})

4. 查询练习
查看班级所人信息

db.class.find()

查看年龄大于10岁的学生信息

db.class.find({age:{$gt:10}})

查看年龄 8-11 岁之间的学生信息

db.class.find({age:{$gt:8,$lt:11}})

找到年龄9岁且为男生的学员

db.class.find({age:9,sex:'m'})

找到年龄小于7岁或者大于11岁的学生

db.class.find({$or:[{age:{$gt:11}},{age:{$lt:7}}]})

找到年龄8岁或者11岁的学生

db.class.find({age:{$in:[8,11]}})

找到有两项兴趣爱好的学生

db.class.find({hobby:{$size:2}})

找到喜欢computer的学生

db.class.find({hobby:"computer"})

找到既喜欢画画,又喜欢跳舞的学生

db.class.find({hobby:{$all:['draw','dance']}})

统计兴趣爱好有3项的学生人数

db.class.find({hobby:{$size:3}}).count()

找到本班年龄第二大的学生

db.class.find({}).sort({age:-1}).skip(1).limit(1)

查看学生学生兴趣爱好的范围

db.class.distinct('hobby')

找到年龄最小的三个同学

db.class.find({}).sort({age:1}).limit(3)

删除虽有年龄小于6岁或者大于12岁的学员

db.class.remove({$or:[{age:{$lt:6}},{age:{$gt:12}}]}) 





相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。   相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
相关文章
|
5天前
|
存储 NoSQL MongoDB
数据库数据恢复—MongoDB数据库迁移过程中丢失文件的数据恢复案例
某单位一台MongoDB数据库由于业务需求进行了数据迁移,数据库迁移后提示:“Windows无法启动MongoDB服务(位于 本地计算机 上)错误1067:进程意外终止。”
|
2月前
|
存储 JSON NoSQL
学习 MongoDB:打开强大的数据库技术大门
MongoDB 是一个基于分布式文件存储的文档数据库,由 C++ 编写,旨在为 Web 应用提供可扩展的高性能数据存储解决方案。它与 MySQL 类似,但使用文档结构而非表结构。核心概念包括:数据库(Database)、集合(Collection)、文档(Document)和字段(Field)。MongoDB 使用 BSON 格式存储数据,支持多种数据类型,如字符串、整数、数组等,并通过二进制编码实现高效存储和传输。BSON 文档结构类似 JSON,但更紧凑,适合网络传输。
82 15
|
2月前
|
存储 NoSQL 关系型数据库
阿里云数据库MongoDB版助力信也科技 打造互联网金融企业样板
我们的风控系统引入阿里云数据库MongoDB版后,解决了特征类字段灵活加减的问题,大大提高了开发效率,极大的提升了业务用户体验,获得了非常好的效果
阿里云数据库MongoDB版助力信也科技 打造互联网金融企业样板
|
3月前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
269 45
|
3月前
|
安全 数据库 开发者
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第26天】本文详细介绍了如何在Django框架下进行全栈开发,包括环境安装与配置、创建项目和应用、定义模型类、运行数据库迁移、创建视图和URL映射、编写模板以及启动开发服务器等步骤,并通过示例代码展示了具体实现过程。
112 2
|
23天前
|
存储 缓存 Java
Python高性能编程:五种核心优化技术的原理与Python代码
Python在高性能应用场景中常因执行速度不及C、C++等编译型语言而受质疑,但通过合理利用标准库的优化特性,如`__slots__`机制、列表推导式、`@lru_cache`装饰器和生成器等,可以显著提升代码效率。本文详细介绍了这些实用的性能优化技术,帮助开发者在不牺牲代码质量的前提下提高程序性能。实验数据表明,这些优化方法能在内存使用和计算效率方面带来显著改进,适用于大规模数据处理、递归计算等场景。
58 5
Python高性能编程:五种核心优化技术的原理与Python代码
|
2月前
|
Python
[oeasy]python055_python编程_容易出现的问题_函数名的重新赋值_print_int
本文介绍了Python编程中容易出现的问题,特别是函数名、类名和模块名的重新赋值。通过具体示例展示了将内建函数(如`print`、`int`、`max`)或模块名(如`os`)重新赋值为其他类型后,会导致原有功能失效。例如,将`print`赋值为整数后,无法再用其输出内容;将`int`赋值为整数后,无法再进行类型转换。重新赋值后,这些名称失去了原有的功能,可能导致程序错误。总结指出,已有的函数名、类名和模块名不适合覆盖赋新值,否则会失去原有功能。如果需要使用类似的变量名,建议采用其他命名方式以避免冲突。
52 14
|
2月前
|
分布式计算 大数据 数据处理
技术评测:MaxCompute MaxFrame——阿里云自研分布式计算框架的Python编程接口
随着大数据和人工智能技术的发展,数据处理的需求日益增长。阿里云推出的MaxCompute MaxFrame(简称“MaxFrame”)是一个专为Python开发者设计的分布式计算框架,它不仅支持Python编程接口,还能直接利用MaxCompute的云原生大数据计算资源和服务。本文将通过一系列最佳实践测评,探讨MaxFrame在分布式Pandas处理以及大语言模型数据处理场景中的表现,并分析其在实际工作中的应用潜力。
116 2
|
2月前
|
Unix Linux 程序员
[oeasy]python053_学编程为什么从hello_world_开始
视频介绍了“Hello World”程序的由来及其在编程中的重要性。从贝尔实验室诞生的Unix系统和C语言说起,讲述了“Hello World”作为经典示例的起源和流传过程。文章还探讨了C语言对其他编程语言的影响,以及它在系统编程中的地位。最后总结了“Hello World”、print、小括号和双引号等编程概念的来源。
126 80

热门文章

最新文章