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

  • 相关阅读:
    Java bytesToHexString 解析
    Redis 启动警告错误解决
    Jackson
    HttpClient和HttpURLConnection的区别
    (HttpURLConnection)强制转化
    由sqlite在手机上的存储位置,引发的onCreate在哪里执行的小结
    Android数据存储五种方式总结
    Android 操作SQLite基本用法
    Android中SQLite应用详解
    android基础
  • 原文地址:https://www.cnblogs.com/mashuqi/p/10979329.html
Copyright © 2020-2023  润新知