日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python连接mongodb进行查询_Python中的MongoDB基本操作:连接、查询实例

發布時間:2025/3/20 python 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python连接mongodb进行查询_Python中的MongoDB基本操作:连接、查询实例 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

MongoDB是一個基于分布式文件存儲的數據庫。由C++語言編寫。旨在為WEB應用提供可護展的高性能數據存儲解決方案。它的特點是高性能、易部署、易使用,存儲數據非常方便。

MongoDB 簡單使用

聯接數據庫

復制代碼 代碼如下:

In [1]: import pymongo

In [2]: from pymongo import Connection

In [3]: connection = Connection('192.168.1.3', 27017) //創建聯接

Connection 相關參數

復制代碼 代碼如下:

Connection([host='localhost'[, port=27017[, pool_size=None[, auto_start_request=None[, timeout=None[, slave_okay=False[, network_timeout=None[, document_class=dict[, tz_aware=True]]]]]]]]])

數據庫操作

復制代碼 代碼如下:

In [9]: c.database_names() //列出所有數據庫名稱

Out[9]: [u'test', u'admin', u'yuhen', u'sms', u'local']

In [10]: c.server_info() //查看服務器相關信息

Out[10]:

{u'bits': 64,

u'gitVersion': u'nogitversion',

u'ok': 1.0,

u'sysInfo': u'Linux yellow 2.6.24-27-server #1 SMP Fri Mar 12 01:23:09 UTC 2010 x86_64 BOOST_LIB_VERSION=1_40',

u'version': u'1.2.2'}

In [16]: db = c['test'] //選擇數據庫

In [17]: db.collection_names() //列出當前數據庫中所有集合名稱

Out[17]: [u'system.indexes', u'fs.files', u'fs.chunks', u'test_gao']

In [23]: db.connection //查看聯接信息

Out[23]: Connection('192.168.1.3', 27017)

In [24]: db.create_collection('test_abeen') //創建新集合

Out[24]: Collection(Database(Connection('192.168.1.3', 27017), u'test'), u'test_abeen')

In [25]: db.last_status() //查看上次操作狀態

Out[25]: {u'err': None, u'n': 0, u'ok': 1.0}

In [26]: db.name //查看當前數據庫名稱

Out[26]: u'test'

In [27]: db.profiling_info() //查看配置信息

Out[27]: []

In [28]: db.profiling_level()

Out[28]: 0.0

集合操作

復制代碼 代碼如下:

In [31]: db.collection_names() //查看當前數據庫所有集合名稱

Out[31]:

[u'system.indexes',

u'fs.files',

u'fs.chunks',

u'test_gao',

u'system.users',

u'test_abeen']

In [32]: c = db.test_abeen //選擇集合

In [33]: c.name //查看當前集合名稱

Out[33]: u'test_abeen'

In [35]: c.full_name //查看當前集合全名

Out[35]: u'test.test_abeen'

In [36]: c.database //查看當前集合數據庫相關信息

Out[36]: Database(Connection('192.168.1.3', 27017), u'test')

In [38]: post = {"author":"Mike","text":"this is a test by abeen"}

In [39]: posts = db.posts

In [40]: posts.insert(post) //向數據庫集合插入文檔,默認創建集合

Out[40]: ObjectId('4c358492421aa91e70000000')

In [41]: db.collection_names() //顯示所有集合名稱

Out[41]:

[u'system.indexes',

u'fs.files',

u'fs.chunks',

u'test_gao',

u'system.users',

u'test_abeen',

u'posts']

In [42]: posts.find_one() //從集合查找信息

Out[42]:

{u'_id': ObjectId('4c358492421aa91e70000000'),

u'author': u'Mike',

u'text': u'this is a test by abeen'}

In [52]: p.update({"author":"Mike"},{"$set":{"author":"abeen","text":"this is a test by abeen shan shan"}})//更新集合文檔信息

In [55]: list(p.find())

Out[55]:

[{u'_id': ObjectId('4c358492421aa91e70000000'),

u'author': u'abeen',

u'text': u'this is a test by abeen shan shan'}]

In [96]: list(posts.find())

Out[96]:

[{u'_id': ObjectId('4c358492421aa91e70000000'),

u'author': u'Mike',

u'text': u'this is a test by abeen'},

{u'_id': ObjectId('4c358ad4421aa91e70000002'), u'a': u'aa', u'b': u'bb'},

{u'_id': ObjectId('4c358ad9421aa91e70000003'), u'a': u'aa', u'b': u'bb'},

{u'_id': ObjectId('4c358abb421aa91e70000001'),

u'a': u'abeen',

u'b': u'this bb is updated'}]

In [97]: posts.remove({"a":"abeen"}) //刪除符合條件的文檔

In [98]: list(posts.find())

Out[98]:

[{u'_id': ObjectId('4c358492421aa91e70000000'),

u'author': u'Mike',

u'text': u'this is a test by abeen'},

{u'_id': ObjectId('4c358ad4421aa91e70000002'), u'a': u'aa', u'b': u'bb'},

{u'_id': ObjectId('4c358ad9421aa91e70000003'), u'a': u'aa', u'b': u'bb'}]

In [102]: db.collection_names()

Out[102]:

[u'system.indexes',

u'fs.files',

u'fs.chunks',

u'test_gao',

u'system.users',

u'test_abeen',

u'posts',

u'doc_abeen']

In [104]: db.drop_collection("doc_abeen") //刪除集合

In [105]: db.collection_names()

Out[105]:

[u'system.indexes',

u'fs.files',

u'fs.chunks',

u'test_gao',

u'system.users',

u'test_abeen',

u'posts']

代碼

復制代碼 代碼如下:

In [113]: result = db.posts.find({"a":"aa"})//查找

In [114]: type(result)

Out[114]:

In [119]: list(result)

Out[119]:

[{u'_id': ObjectId('4c358ad4421aa91e70000002'), u'a': u'aa', u'b': u'bb'},

{u'_id': ObjectId('4c358ad9421aa91e70000003'), u'a': u'aa', u'b': u'bb'}]

find格式

復制代碼 代碼如下:

find([spec=None[, fields=None[, skip=0[, limit=0[, timeout=True[, snapshot=False[, tailable=False[, sort=None[, max_scan=None[, as_class=None[, **kwargs]]]]]]]]]]])

代碼

復制代碼 代碼如下:

In [120]: db.posts.count()//當前集合文檔數

Out[120]: 3

In [121]: type(db.posts)

Out[121]:

In [138]: posts.rename('test_abeen')//重命名當前集合

In [139]: db.collection_names()

Out[139]:

[u'system.indexes',

u'fs.files',

u'fs.chunks',

u'test_gao',

u'system.users',

u'test_abeen']

In [151]: for post in c.find({"a":"aa"}).sort("a"): //查詢并排序列

post

Out[152]: {u'_id': ObjectId('4c358ad4421aa91e70000002'), u'a': u'aa', u'b': u'bb'}

Out[152]: {u'_id': ObjectId('4c358ad9421aa91e70000003'), u'a': u'aa', u'b': u'bb'}

復制代碼 代碼如下:

> db.foo.insert( { x : 1, y : 1 } )

> db.foo.insert( { x : 2, y : "string" } )

> db.foo.insert( { x : 3, y : null } )

> db.foo.insert( { x : 4 } )

// Query #1 y 為null或不存在

> db.foo.find( { "y" : null } )

{ "_id" : ObjectId("4dc1975312c677fc83b5629f"), "x" : 3, "y" : null }

{ "_id" : ObjectId("4dc1975a12c677fc83b562a0"), "x" : 4 }

// Query #2 y為null的值

> db.foo.find( { "y" : { $type : 10 } } )

{ "_id" : ObjectId("4dc1975312c677fc83b5629f"), "x" : 3, "y" : null }

// Query #3 y不存在的結果

> db.foo.find( { "y" : { $exists : false } } )

{ "_id" : ObjectId("4dc1975a12c677fc83b562a0"), "x" : 4 }

本文標題: Python中的MongoDB基本操作:連接、查詢實例

本文地址: http://www.cppcns.com/shujuku/mongodb/119740.html

總結

以上是生活随笔為你收集整理的python连接mongodb进行查询_Python中的MongoDB基本操作:连接、查询实例的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。