Django检查User.name是否已在数据库中 - 通过user.name而不是user.id进行匹配

时间:2014-02-04 02:51:05

标签: python database django django-models

我有一个简单的个人Django项目,它允许某人通过在索引页面上提供用户名和消息来创建消息。然后,他们可以通过数据库中的该链接查看给定用户的所有消息。理想情况下,guest虚拟机会键入其用户名和消息,如果用户名不在数据库中,则会创建该消息并保存消息。但是,如果它在数据库中,则该消息与该现有用户名链接,当我查看用户的所有消息时,应显示旧消息和当前消息。

我现在面临的问题是我无法找到当前消息并将其链接到现有用户名。例如

User: Josh
Message: Hello World

User: Josh
Message: Second time.

两个用户在数据库中都有单独的ID,因此当我查看来自'Josh'的消息时,它只给我一个或另一个。我希望他们在Josh第二次输入时联系起来,这样当我查看Josh时,所有消息都会显示出来。 Essentially, how do I match them via User.name rather than User.id?

模型

class User (models.Model):
    name = models.CharField(max_length=20)

    def __unicode__(self):              
        return self.name

class Message (models.Model):
    content = models.TextField(max_length=140)
    user = models.ForeignKey(User)
    time = models.DateTimeField()

    def __unicode__(self):              
        return self.content

views.py

def index (request):
    if request.method == 'POST':
        u = User(name=request.POST.get('user'))
        u.save()
        m = Message(content=request.POST.get('message'), user = u)
        m.save()
        return render_to_response('index.html', {
                'user': u,
                'message': m,
                }, RequestContext(request))
    else:
        u = User()
        m = Message()
        return render_to_response('index.html', {
                'user': u,
                'message': m,
                }, RequestContext(request))

def view_messages(request, user_name=None):
    if user_name:
        user = get_object_or_404(User,pk=user_name)
        return render_to_response('messages.html', {
            'user': user,
            'messages': Message.objects.filter(user=user)
            })
    else:
        return render_to_response('messages.html', {
            'messages': Message.objects.all(),
            })

的index.html

<form action="{% url 'index' %}" id="user_form" method = "POST">
{% csrf_token %}
<input type="text" name="user" id="user" maxlength="20" placeholder="Username" onblur="return validUser(this)">
<br>
<br>
<textarea rows="4" cols="35" name="message"  id="message" maxlength="140" placeholder="Message goes here" onblur="return validMessage(this)"></textarea><br>
<input type="submit" value="Submit" onclick="return finalCheck()">
</form>

谢谢!

1 个答案:

答案 0 :(得分:-1)

您必须在定义类成员时设置primary_key=True参数。否则,Django会添加一个自动ID字段,如here所述。

试试这个Model类:

class User (models.Model):
    name = models.CharField(max_length=20, primary_key=True)

    def __unicode__(self):
        return self.name