欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

在Python中使用MongoEngine操作數(shù)據(jù)庫教程實(shí)例

 更新時(shí)間:2019年12月03日 11:17:35   作者:慕塵  
這篇文章主要介紹了在Python中使用MongoEngine操作數(shù)據(jù)庫教程實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

這篇文章主要介紹了在Python中使用MongoEngine操作數(shù)據(jù)庫教程實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

pymongo來操作MongoDB數(shù)據(jù)庫,但是直接把對于數(shù)據(jù)庫的操作代碼都寫在腳本中,這會(huì)讓應(yīng)用的代碼耦合性太強(qiáng),而且不利于代碼的優(yōu)化管理

一般應(yīng)用都是使用MVC框架來設(shè)計(jì)的,為了更好地維持MVC結(jié)構(gòu),需要把數(shù)據(jù)庫操作部分作為model抽離出來,這就需要借助MongoEngine

MongoEngine是一個(gè)對象文檔映射器(ODM),相當(dāng)于一個(gè)基于SQL的對象關(guān)系映射器(ORM)

MongoEngine提供的抽象是基于類的,創(chuàng)建的所有模型都是類

安裝

pip install mongoengine

使用時(shí)先聲明一個(gè)繼承自MongoEngine.Document的類

在類中聲明一些屬性,相當(dāng)于創(chuàng)建一個(gè)用來保存數(shù)據(jù)的數(shù)據(jù)結(jié)構(gòu),即數(shù)據(jù)已類似數(shù)據(jù)結(jié)構(gòu)的形式存入數(shù)據(jù)庫中,通常把這樣的一些類都存放在一個(gè)腳本中,作為應(yīng)用的Model模塊

from mongoengine import *
connect('test', host='localhost', port=27017)
import datetime
class Users(Document):
  name = StringField(required=True, max_length=200)
  age = IntField(required=True)

users = Users.objects.all() #返回所有的文檔對象列表
for u in users:
  print("name:",u.name,",age:",u.age)

保存文檔

from mongoengine import *
connect('test', host='localhost', port=27017)
import datetime
class Users(Document):
  name = StringField(required=True, max_length=200)
  age = IntField(required=True)
user1 = Users(
  name='zz',
  age= 11
)
user1.save()  
print(user1.name)
user1.name = 'zz11'
user1.save()    
print(user1.name)

查詢10=<年齡<30的,按姓名排列

from mongoengine import *
connect('test', host='localhost', port=27017)
import datetime
class Users(Document):
  name = StringField(required=True, max_length=200)
  age = IntField(required=True)
user_search = Users.objects(age__gte=10, age__lt=33).order_by('name')
for u in user_search:
  print("name:",u.name,",age:",u.age)

查詢10=<年齡<30的,按姓名倒序

from mongoengine import *
connect('test', host='localhost', port=27017)
import datetime
class Users(Document):
  name = StringField(required=True, max_length=200)
  age = IntField(required=True)
user_search = Users.objects(age__gte=10, age__lt=33).order_by('-name')
for u in user_search:
  print("name:",u.name,",age:",u.age)

查詢name=zz11

from mongoengine import *
connect('test', host='localhost', port=27017)
import datetime
class Users(Document):
  name = StringField(required=True, max_length=200)
  age = IntField(required=True)

tmp = Users.objects(name="zz11")
for u in tmp:
  print("name:",u.name,",age:",u.age)

修改name=zz11的age加1

from mongoengine import *
connect('test', host='localhost', port=27017)
import datetime
class Users(Document):
  name = StringField(required=True, max_length=200)
  age = IntField(required=True)
tmp = Users.objects(name="zz11").update(inc__age=1)
tmp = Users.objects(name="zz11")
for u in tmp:
  print("name:",u.name,",age:",u.age)

修改name=zz11的age設(shè)為55

from mongoengine import *
connect('test', host='localhost', port=27017)
import datetime
class Users(Document):
  name = StringField(required=True, max_length=200)
  age = IntField(required=True)

tmp = Users.objects(name="zz11").update(set__age=55)
tmp = Users.objects(name="zz11")
for u in tmp:
  print("name:",u.name,",age:",u.age)

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python計(jì)算兩個(gè)矩形重合面積代碼實(shí)例

    Python計(jì)算兩個(gè)矩形重合面積代碼實(shí)例

    這篇文章主要介紹了Python 實(shí)現(xiàn)兩個(gè)矩形重合面積代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-09-09
  • Python 使用type來定義類的實(shí)現(xiàn)

    Python 使用type來定義類的實(shí)現(xiàn)

    今天小編就為大家分享一篇Python 使用type來定義類的實(shí)現(xiàn),具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • Python中的列表生成式與生成器學(xué)習(xí)教程

    Python中的列表生成式與生成器學(xué)習(xí)教程

    這篇文章主要介紹了Python中的列表生成式與生成器學(xué)習(xí)教程,Python中的Generator生成器比列表生成式功能更為強(qiáng)大,需要的朋友可以參考下
    2016-03-03
  • python help函數(shù)實(shí)例用法

    python help函數(shù)實(shí)例用法

    在本篇文章里小編給大家整理了關(guān)于python help函數(shù)實(shí)例用法及相關(guān)實(shí)例,需要的朋友們可以學(xué)習(xí)下。
    2020-12-12
  • python實(shí)現(xiàn)WebSocket服務(wù)端過程解析

    python實(shí)現(xiàn)WebSocket服務(wù)端過程解析

    這篇文章主要介紹了python實(shí)現(xiàn)WebSocket服務(wù)端過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-10-10
  • python 實(shí)現(xiàn)求解字符串集的最長公共前綴方法

    python 實(shí)現(xiàn)求解字符串集的最長公共前綴方法

    今天小編就為大家分享一篇python 實(shí)現(xiàn)求解字符串集的最長公共前綴方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-07-07
  • python按照list中字典的某key去重的示例代碼

    python按照list中字典的某key去重的示例代碼

    這篇文章主要介紹了python按照list中字典的某key去重的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10
  • pymysql模塊的使用(增刪改查)詳解

    pymysql模塊的使用(增刪改查)詳解

    這篇文章主要介紹了pymysql模塊的使用(增刪改查)詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-09-09
  • Python中類的mro與繼承關(guān)系詳解(二)

    Python中類的mro與繼承關(guān)系詳解(二)

    這篇文章主要介紹了Python中類的mro與繼承關(guān)系詳解,上一篇我們已經(jīng)通過mro相關(guān)資料介紹了mro繼承關(guān)系的基礎(chǔ)內(nèi)容,這片緊接著上一篇文章展開詳細(xì)內(nèi)容,需要的朋友可以參考一下
    2022-07-07
  • Python?多線程知識(shí)點(diǎn)總結(jié)及實(shí)例用法

    Python?多線程知識(shí)點(diǎn)總結(jié)及實(shí)例用法

    在本篇內(nèi)容里小編給大家整理了一篇關(guān)于Python?多線程知識(shí)點(diǎn)總結(jié)及實(shí)例用法,對想好學(xué)習(xí)PY的用戶非常友好,需要的參考下吧。
    2021-12-12

最新評論