码迷,mamicode.com
首页 > 编程语言 > 详细

python测试开发django-12.models设置主键primary_key

时间:2019-01-28 18:19:56      阅读:192      评论:0      收藏:0      [点我收藏+]

标签:字符   图片   max   use   primary   .com   key   hello   name   

前言

django的models新增数据库表时,如果不设置主键,会默认新增一个id为主键,如果我们想自己设置一个字段为主键,需加个参数primary_key=True

默认id主键

新增一张用户表,表名为user 字段user_name, psw ,mail 都是字符串类型,设计如下

# models.py

from django.db import models

# Create your models here.
 
# 我们新建了一个Person类,继承自models.Model,
class Person(models.Model):
    name = models.CharField(max_length=30)
    age = models.IntegerField()

# 新增一张用户表,表名为user 字段user_name, psw ,mail 都是字符串类型
class User(models.Model):
    user_name = models.CharField(max_length=30)
    psw = models.CharField(max_length=30)
    mail = models.CharField(max_length=30)

cmd执行makemigrations和migrate

python manage.py makemigrations
python manage.py migrate

然后就可以看到hello_user表新增成功了,默认多一个字段id为主键

技术分享图片

设置主键primary_key

新增一张用户表,表名为user 字段user_name(主键), psw ,mail 都是字符串类型,我们设置user_name为主键,让用户名不重复,设计如下

# models.py

from django.db import models

# Create your models here.
 
# 我们新建了一个Person类,继承自models.Model,
class Person(models.Model):
    name = models.CharField(max_length=30)
    age = models.IntegerField()

# 新增一张用户表,表名为user 字段user_name, psw ,mail 都是字符串类型
class User(models.Model):
    user_name = models.CharField(max_length=30,
                                 primary_key=True)   # 设置为主键
    psw = models.CharField(max_length=30)
    mail = models.CharField(max_length=30)

cmd执行makemigrations和migrate

python manage.py makemigrations
python manage.py migrate

然后就可以看到hello_user表新增成功了,主键user_name就会代替默认的id主键了

技术分享图片

python测试开发django-12.models设置主键primary_key

标签:字符   图片   max   use   primary   .com   key   hello   name   

原文地址:https://www.cnblogs.com/yoyoketang/p/10331233.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!