django 小知识

数据库查询中的Question.objects.get(pk=1)是什么意思?

在看某些django例子的时候,涉及到django的数据库模型映射,总会有这么一些代码

# 关键字参数
def detail(request, question_id):
    question = get_object_or_404(Question, pk=question_id)
    return render(request, 'polls/detail.html', {'question': question})

# 或者直接这样
Question.objects.get(pk=1)

这里的pk是什么意思呢?

查看django的文档发现,pk其实就是primary key的缩写

django的模型创建的时候,会自动在数据库写入一个自增的id字段,这个字段并不需要显示地写在模型里面,和一般数据表的创建类似,由于其独一无二性,被设置成了该表的主键,也就是索引

所以,上面查询的方式其实等价于下面这种写法

# 关键字参数
def detail(request, question_id):
    # question = get_object_or_404(Question, pk=question_id)
    question = get_object_or_404(Question, id=question_id)
    return render(request, 'polls/detail.html', {'question': question})

# 或者直接这样
Question.objects.get(id=1)

不过需要注意的是,当设置了其他的主键,则无法进行如此的等价,一般来说,pk的定义简化了主键的查询,可以是id,也可以是其他的字段名,具体就看自己数据库模型的定义了。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章