Django 在模型中保存数据时user.id出错-Commit False不工作
我正在使用Django 在模型中保存数据时user.id出错-Commit False不工作,django,django-models,Django,Django Models,我正在使用AbstractBaseUser,为此我创建了一个managers.py来创建超级用户 除了managers.py中的这些行之外,其他所有内容都正常工作。甚至在user.save(using=self.\u db)之前,我也尝试了print(user.id)打印None user.save(using=self._db) user.created_by_id = user.id user.updated_by_id = user.id user.save() 我在user.save中
AbstractBaseUser
,为此我创建了一个managers.py
来创建超级用户
除了managers.py中的这些行之外,其他所有内容都正常工作。甚至在user.save(using=self.\u db)
之前,我也尝试了print(user.id)
打印None
user.save(using=self._db)
user.created_by_id = user.id
user.updated_by_id = user.id
user.save()
我在user.save中也使用了commit=False
(使用=self.\u db,commit=False)
但它仍然给出了错误。请参阅底部的错误
在my models.py中,我有一个twoo字段由
创建和由
更新,该字段不应为空。这就是我保存Managers.py的原因,它产生了所有这些错误
我怎样才能解决这个问题。是否有更好的方法。仅在创建超级用户时才需要此条件
Models.py
class User(AbstractBaseUser, PermissionsMixin):
email = models.EmailField(_('email address'), unique=True)
first_name = models.CharField(_('first name'), max_length=30, blank=True)
last_name = models.CharField(_('last name'), max_length=30, blank=True)
is_active = models.BooleanField(_('is user active'), default=True)
profile_image = models.ImageField(default='user-avatar.png', upload_to='users/', null=True, blank=True)
is_staff = models.BooleanField(_('staff'), default=True)
role = models.ForeignKey(Role, on_delete=models.CASCADE)
phone_number = models.CharField(max_length=30, blank=True, null=True)
address = models.CharField(max_length=100, blank=True, null=True)
created_by = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE, blank=True, related_name='user_created_by')
created_on = models.DateTimeField(_('user created on'), auto_now_add=True)
updated_by = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE, blank=True, related_name='user_updated_by')
updated_on = models.DateTimeField(_('user updated on'), auto_now=True)
经理.py
class UserManager(BaseUserManager):
use_in_migrations = True
def _create_user(self, email, password, **extra_fields):
"""
Creates and saves a User with the given email and password.
"""
if not email:
raise ValueError('The given email must be set')
email = self.normalize_email(email)
user = self.model(email=email, **extra_fields)
user.set_password(password)
user.role_id = 1
user.first_name = "Super"
user.last_name = "Admin"
user.save(using=self._db)
user.created_by_id = user.id
user.updated_by_id = user.id
user.save()
return user
def create_user(self, email, password=None, **extra_fields):
extra_fields.setdefault('is_superuser', False)
return self._create_user(email, password, **extra_fields)
def create_superuser(self, email, password, **extra_fields):
extra_fields.setdefault('is_superuser', True)
if extra_fields.get('is_superuser') is not True:
raise ValueError('Superuser must have is_superuser=True.')
return self._create_user(email, password, **extra_fields)
错误-对于commit=False
super().save(*args, **kwargs)
TypeError: save() got an unexpected keyword argument 'commit'
错误-不提交False
raise utils.IntegrityError(*tuple(e.args))
django.db.utils.IntegrityError: (1048, "Column 'created_by_id' cannot be null")
commit=False
适用于。它不适用于模型实例。正如问题中所述,方法中不存在名为commit
的关键字参数
此外,在保存用户对象之前,它不能生成任何主键。我建议将
created\u设置为空。这样可以避免完整性错误
created_by = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE, blank=True, related_name='user_created_by', null=True, default=None)
updated_by = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE, blank=True, related_name='user_updated_by', null=True, default=None)
不过,如果您想要强制执行此限制,那么您可以在表单或序列化程序中执行此操作,或者在User
模型中重写save方法
例如:
class User(...):
...
def save(self, *args, **kwargs):
if not self.is_superuser:
if not self.created_by or not self.updated_by:
raise Exception("Add these fields") # can be custom exception
super(User, self).save(*args, **kwargs)
以前我将它保留为
null=True
。但是由于我将来将要面对的一些问题,我将它保留为null=False
。有什么不同的方法吗