我是mongodb和django的新手。我在django中设置了所有models
和urls.py
。但是它有时间在视图页面上检索数据库的信息。
我的数据库看起来像:
{
"_id": {
"$oid": "52221778633a610c58c131e6"
},
"text": "just",
"tags": [
"mongo",
"django"
],
"comments": [],
"title": "hello" }
数据库名称:事件集合名称:polls_post
我的urls.py
看起来像是:
from django.conf.urls.defaults import patterns, include, url
from django.views.generic import ListView, DetailView
from polls.models import Post
urlpatterns = patterns('',
url(r'^time/$','polls.views.current_datetime'),
url(r'^events/$','polls.views.events'),
)
我的views.py
看起来像:
from django.http import HttpResponse
import datetime
def current_datetime(request):
now = datetime.datetime.now()
html = "<html><body>It is now %s.</body></html>" % now
return HttpResponse(html)
def events(request):
html = "<html><body>title is:<h1></h1></body></html>"
return HttpResponse(html)
那么,我们如何从数据库中获取文本,标题和注释,以便它可以在网页上显示?
答案 0 :(得分:3)
要访问数据库,django有一些叫做模型的东西。这是一个完整的fletched ORM来抽象底层数据库的基本要素。 Django的ORM完全适用于Relational DB。 Mongo是NoSQL,我们必须寻找其他选择。 MongoDB使用最广泛的ORM包括Mongokit和MongoEngine。这些是在Pymongo之上构建的包装器。 为简单起见,这里有一个简短的代码片段,用于使用pymongo从mongoDB中获取数据。
from pymongo import Connection
server="localhost"
port = 27017
#Establish a connection with mongo instance.
conn = Connection(server,port)
要从集合中获取单个文档,请使用find_one。
poll = conn.events.polls_post.find_one({},{"title" : 1}) #first parameter is the query, second one is the projection.
print "Title : ", poll['title']
要从集合中获取所有文档,请使用find。
polls = conn.events.polls_post.find({},{"title" : 1})#first parameter is the query, second one is the projection.
for poll in polls:
print "Title : ",poll['title']
如果您想使用Django的非关系引擎,您可以写:
from models import Post
posts = Post.objects.all()
for post in posts:
print post.title
这假设您已经在models.py中创建了一个模型类:如下所示:
class Post(models.Model):
created_on = models.DateTimeField(auto_now_add=True, null=True)
title = models.CharField()
text = models.TextField()
tags = ListField()
有关更实用的内容,请结帐:pymongo和MognoDB。 要使用Django的非关系引擎结帐:Django Non Relational Engine
谢谢!
答案 1 :(得分:0)
这用于显示mongodb中我们在django应用程序中连接的ip的所有数据库的列表 ***** 这对我有用 *******
来自django.db导入连接 进口pymongo
mongo1 = pymongo.Connection('127.0.0.1')
print mongo1.database_names()
答案 2 :(得分:0)
In Views:
def user_add(request):
if request.method == "POST":
# do save process
else:
#brand_list = UserModule.objects.all()
brand_list = UserModule.objects.values('department','designation','division')
return render_to_response('useradd.html', {'brand_list': brand_list},
context_instance=RequestContext(request))
在Html页面
<select name="designation" class="form-control" id="designation">
<option value="Z">Select a designation</option>
{% for brand in brand_list %}
<option>
{%for i in brand.designation%}
{{ i }}
{%endfor%}
</option>
{% endfor %}
</select>