찾다
백엔드 개발파이썬 튜토리얼Python3으로 Mongodb를 작동하는 방법에 대한 간단하고 명확한 튜토리얼

이 글에서는 Python3 동작Mongodb간결하고 이해하기 쉬운 튜토리얼을 중심으로 데이터베이스 연결 방법과 데이터베이스 동작 방법을 자세히 소개합니다. 더 자세히 알아보세요.

데이터베이스에 연결

데이터베이스에 연결하려면 주소와 인터페이스를 제공해야 합니다. 먼저 패키지를 가져와야 합니다.

from pymongo import MongoClient
conn = MongoClient('localhost',27017)

물론, 다음과 같은 작성 방법을 사용할 수 있습니다.

conn = MongoClient('mongodb://localhost:27017/')

데이터베이스 생성

mongodb는 미리 데이터베이스를 생성할 필요는 없고, 존재하는 것으로 확인되면 직접 사용합니다. 데이터베이스가 없으면 자동으로 생성됩니다.

db = conn.testdb

위 명령문은 testdb 데이터베이스를 생성합니다. 단, 데이터 삽입이 없는 경우 관리 도구에서 해당 데이터베이스를 볼 수 없습니다(표시되지 않음).

데이터 삽입

우선, 첫 번째 단계는 데이터를 삽입하고 살펴보는 것입니다.

단일 레코드 삽입

from pymongo import MongoClient
conn = MongoClient('mongodb://localhost:27017/')
db = conn.testdb
db.col.insert({"name":'yanying','province':'江苏','age':25})

참고: 다음 작업에서는 데이터베이스 연결 작업이 무시되며 핵심 코드가 직접 작성됩니다.

Python 콘솔에서는 아무 일도 일어나지 않습니다. 이것이 바로 성공을 의미합니다. 관리 도구를 사용하여 데이터베이스 기록을 확인하세요. 여기에는 데이터가 포함되어 있습니다.

다중 레코드 삽입

Mongodb는 한 번에 여러 데이터 조각을 삽입할 수도 있습니다.

db.col.insert([
 {"name":'yanying','province':'江苏','age':25},
 {"name":'张三','province':'浙江','age':24},
 {"name":'张三1','province':'浙江1','age':25},
 {"name":'张三2','province':'浙江2','age':26},
 {"name":'张三3','province':'浙江3','age':28},
])

Querydata

이제 방금 삽입한 데이터를 쿼리하겠습니다.

단일 쿼리

find_one()을 사용하여 레코드를 쿼리할 수 있습니다.

db.col.find_one()

위 명령문은 mongodb 레코드를 쿼리할 수 있습니다. 레코드의 추가 _id는 Mongodb에서 자동으로 생성된 고유 값입니다.

코드 복사 코드는 다음과 같습니다.

{'_id': ObjectId('5925351ad92fac3250b9ae3f'), 'name': 'yanying', 'province': '江苏', 'age': 25}

다음 작업에 대한 일부 데이터를 삽입해 보겠습니다. (수만 단어 생략)

전체 쿼리

모든 레코드를 쿼리해야 하는 경우 db.col.find()를 사용할 수 있지만 찾은 것은 결과 리소스 집합입니다.

모든 기록을 나열하려면 for를 사용할 수 있습니다.

for item in db.col.find():
 print(item)

이렇게 하면 모든 기록을 얻을 수 있습니다.

{'_id': ObjectId('5925351ad92fac3250b9ae3f'), 'name': 'yanying', 'province': '江苏', 'age': 25}
{'_id': ObjectId('592550e5d92fac0b8c449f87'), 'name': 'zhangsan', 'province': '北京', 'age': 29}
{'_id': ObjectId('592550f6d92fac3548c20b1a'), 'name': 'lisi', 'province': '上海', 'age': 22}
{'_id': ObjectId('59255118d92fac43dcb1999a'), 'name': '王二麻', 'province': '广东', 'age': 30}

조건부 쿼리

쿼리 조건을 매개변수로 삽입하면 데이터를 필터링할 수 있습니다.

for item in db.col.find({'name':"yanying"}):
 print(item)

쿼리 결과

코드는 다음과 같습니다.

{'_id': ObjectId('5925351ad92fac3250b9ae3f'), 'name': 'yanying', 'province': '江苏', 'age': 25}

물론 특정 값보다 작은 레코드

for item in db.col.find({"age":{"$lt":25}}):
 print(item)

또는 특정 값보다 큰 레코드

for item in db.col.find({"age":{"$gt":25}}):
 print(item)

Statistical도 쿼리할 수 있습니다. query

위 코드는 모든 레코드 수를 가져오거나

db.col.find().count() // 4

또는 조건을 추가할 수 있습니다.

db.col.find({"age":{"$gt":25}}).count() //2

_id

_id를 기반으로 한 쿼리 레코드는 mongodb에서 자동으로 생성한 ID입니다. ObjectId를 사용하려면 유형을 변환해야 합니다.

이 메서드는 python3에서 제공되지만 라이브러리를 가져와야 합니다.

from bson.objectid import ObjectId

이런 식으로 _id를 직접 사용해 쿼리할 수 있습니다.

collection.find_one({'_id':ObjectId('592550e5d92fac0b8c449f87')})

결과 정렬

정렬해야 할 필드를 sort 메서드에 넣기만 하면 됩니다. Mongodb는 기본적으로 오름차순으로 설정되어 있습니다

db.col.find().sort("age")

. 하지만 일부 매개변수를 추가하여 정렬 방법을 변경할 수도 있습니다. 예를 들어 역순이지만 pymongo 라이브러리를 먼저 가져와야 합니다.

import pymongo
db.col.find().sort("UserName",pymongo.DESCENDING)

오름차순으로 만들 수도 있지만 이것이 기본값입니다.

for item in db.col.find().sort('age',pymongo.ASCENDING):
 print(item)

Updatedata

데이터 업데이트는 매우 간단합니다. 업데이트해야 하는 조건과 데이터가 필요합니다.

코드를 복사할 수 있습니다. 코드는 다음과 같습니다.

db.col.update({'_id':ObjectId('59255118d92fac43dcb1999a')},{'$set':{'name':'王二麻33333'}})

결과는 다음과 같습니다. Wang Erma는 Wang Erma 33333

코드는 다음과 같습니다.

{'_id': ObjectId('59255118d92fac43dcb1999a'), 'name': '王二麻33333', 'province': '广东', 'age': 30}

Deletedata

remove() 메소드를 사용하여 데이터를 삭제합니다. 메소드에 조건이 있으면 지정된 조건 데이터를 삭제하고, 그렇지 않으면 모두 삭제합니다.

이름이 Wang Erma 33333인 사용자를 삭제합니다.

db.col.remove({'name':'王二麻33333'})

모든 데이터 삭제(주의해서 사용)

db.col.remove()

위 내용은 Python3으로 Mongodb를 작동하는 방법에 대한 간단하고 명확한 튜토리얼의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
mongodb php 扩展没有怎么办mongodb php 扩展没有怎么办Nov 06, 2022 am 09:10 AM

mongodb php扩展没有的解决办法:1、在linux中执行“$ sudo pecl install mongo”命令来安装MongoDB的PHP扩展驱动;2、在window中,下载php mongodb驱动二进制包,然后在“php.ini”文件中配置“extension=php_mongo.dll”即可。

Redis和MongoDB的区别与使用场景Redis和MongoDB的区别与使用场景May 11, 2023 am 08:22 AM

Redis和MongoDB都是流行的开源NoSQL数据库,但它们的设计理念和使用场景有所不同。本文将重点介绍Redis和MongoDB的区别和使用场景。Redis和MongoDB简介Redis是一个高性能的数据存储系统,常被用作缓存和消息中间件。Redis以内存为主要存储介质,但它也支持将数据持久化到磁盘上。Redis是一款键值数据库,它支持多种数据结构(例

Go语言中使用MongoDB:完整指南Go语言中使用MongoDB:完整指南Jun 17, 2023 pm 06:14 PM

MongoDB是一种高性能、开源、文档型的NoSQL数据库,被广泛应用于Web应用、大数据以及云计算领域。而Go语言则是一种快速、开发效率高、代码可维护性强的编程语言。本文将为您完整介绍如何在Go语言中使用MongoDB。一、安装MongoDB在使用MongoDB之前,需要先在您的系统中安装MongoDB。在Linux系统下,可以通过如下命令安装:sudo

php7.0怎么安装mongo扩展php7.0怎么安装mongo扩展Nov 21, 2022 am 10:25 AM

php7.0安装mongo扩展的方法:1、创建mongodb用户组和用户;2、下载mongodb源码包,并将源码包放到“/usr/local/src/”目录下;3、进入“src/”目录;4、解压源码包;5、创建mongodb文件目录;6、将文件复制到“mongodb/”目录;7、创建mongodb配置文件并修改配置即可。

php怎么使用mongodb进行增删查改操作php怎么使用mongodb进行增删查改操作Mar 28, 2023 pm 03:00 PM

MongoDB作为一款流行的NoSQL数据库,已经被广泛应用于各种大型Web应用和企业级应用中。而PHP语言也作为一种流行的Web编程语言,与MongoDB的结合也变得越来越重要。在本文中,我们将会学习如何使用PHP语言操作MongoDB数据库进行增删查改的操作。

SpringBoot中logback日志怎么保存到mongoDBSpringBoot中logback日志怎么保存到mongoDBMay 18, 2023 pm 07:01 PM

自定义Appender非常简单,继承一下AppenderBase类即可。可以看到有个AppenderBase,有个UnsynchronizedAppenderBase,还有个AsyncAppenderBase继承了UnsynchronizedAppenderBase。从名字就能看出来区别,异步的、普通的、不加锁的。我们定义一个MongoDBAppender继承UnsynchronizedAppenderBasepublicclassMongoDBAppenderextendsUnsynchron

SpringBoot怎么整合Mongodb实现增删查改SpringBoot怎么整合Mongodb实现增删查改May 13, 2023 pm 02:07 PM

一、什么是MongoDBMongoDB与我们之前熟知的关系型数据库(MySQL、Oracle)不同,MongoDB是一个文档数据库,它具有所需的可伸缩性和灵活性,以及所需的查询和索引。MongoDB将数据存储在灵活的、类似JSON的文档中,这意味着文档的字段可能因文档而异,数据结构也会随着时间的推移而改变。文档模型映射到应用程序代码中的对象,使数据易于处理。MongoDB是一个以分布式数据库为核心的数据库,因此高可用性、横向扩展和地理分布是内置的,并且易于使用。况且,MongoDB是免费的,开源

Swoole与MongoDB的整合:构建高性能的文档数据库系统Swoole与MongoDB的整合:构建高性能的文档数据库系统Jun 14, 2023 am 11:51 AM

在现代企业应用程序开发中,需要处理海量数据和高并发的访问请求。为了满足这些需求,开发人员需要使用高性能的数据库系统,以确保系统的稳定性和可扩展性。本文将介绍如何使用Swoole和MongoDB构建高性能的文档数据库系统。Swoole是一个基于PHP语言开发的异步网络通信框架,它能够大大提高PHP应用程序的性能和并发能力。MongoDB是一种流行的文档数据库,

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경