djongo:Django和MongoDB連接器
用法
1.pip install djongo
2.在Django項目下的setting.py中增加如下代碼:
DATABASES ={
‘default‘:{
‘ENGINE:‘djongo‘,
‘NAME‘:‘your-db-name‘,
}
}
3.運行 manage.py makemigrations,之後運行 manage.py migrate(僅在MongoDB中第一次建立數據表的時候需要)
4.完成。
在這裏還是要推薦下我自己建的Python開發學習群:725479218,群裏都是學Python開發的,如果你正在學習Python ,小編歡迎你加入,大家都是軟件開發黨,不定期分享幹貨(只有Python軟件開發相關的),包括我自己整理的一份2018最新的Python進階資料和高級開發教程,歡迎進階中和進想深入Python的小夥伴
要求:
1.Python3.6及以上版本
2.MongoDB 3.4及以上版本
3.如果項目數據庫中使用嵌套查詢或者子查詢,比如:
inner_qs =Blog.objects.filter(name__contains=‘Ch‘).values(‘name‘) entries =Entry.objects.filter(blog__name__in=inner_qs)
需要MongoDB3.6及以上版本。
如何工作?
Djongo對Django ORM框架的改變非常小,這就意味著不會發生一些不必要的錯誤。它將SQL字符串查詢轉變為MongoDB的文件查詢。至此,所有和Django相關的功能、數據庫等都這樣運作。
Django的服務模塊:
‘django.contrib.admin‘,
‘django.contrib.auth‘,
‘django.contrib.sessions‘,
其它的也全都支持。
Django中用法
用於MongoDB的Djongo連接器確保你可以: --重新使用Django數據庫/ORM框架 --同原始Django變量一起發揮作用 --事先驗證你的代碼 --微小的SQL JOIN操作
參考集成Django和MongoDB獲取更詳細的介紹。如果你的項目使用了復雜的數據庫,也可以向專家獲取支持。
使用Django用戶管理模塊添加數據文件
比如你想利用Django創建一個以MongoDB為後端數據庫的博客平臺。在你博客項目app/models.py文件下定義Blog數據表:
完成設置,然後訪問localhost:80000/admin/你將會看到以下結果。
查詢嵌入的數據字段
在上面的例子中,我們要查詢所有以Beatles開頭的名字,可以使用下面的查詢方法:
參考在Django中使用MongoDB數據字段獲取更多的介紹。
Djongo管理器
Djongo管理器擴展了Django管理器的功能。它能夠讓你使用所有pymongo的API命令。可以在模型中定義類似Djongo管理器一樣的自定義管理器。
管理器的使用和Djongo管理器一樣: post = Entry.objects.get(pk=pkey) 將會獲得一個帶有主鍵pkey的對象。
對Pymongo直接操作
MongoDB有非常強大的查詢命令,DjongoManager能夠讓你完全使用它。
你可以直接使用任何pymongo命令通過在命令名字前面加上mongo的前綴。例如,對Blogpage(Blogpage在SQL中保存為一個數據表,在MongoDB中保存為一個集合)使用aggregate,函數名變為mongoaggregate。在模型中直接插入一個文件(不是使用.save()),使用mongoinsertone() 。
djongo:Django和MongoDB連接器