zoukankan      html  css  js  c++  java
  • python测试开发django-12.models设置主键primary_key

    前言

    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主键了

  • 相关阅读:
    JQuery判断checkbox是否选中-批量
    浮动跟随
    当天时间戳范围
    统计兼职人员打标签数量
    submit回车提交影响
    js 数组去除空值
    js循环
    ajax
    滚动条位置
    oc基础-set和get方法的使用
  • 原文地址:https://www.cnblogs.com/mashuqi/p/10979329.html
Copyright © 2011-2022 走看看