数据库查询中的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,也可以是其他的字段名,具体就看自己数据库模型的定义了。