首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >位于/user/register的部门不能分配"('Civil Engineering (CE)',)":"User.department“必须是”ValueError“实例

位于/user/register的部门不能分配"('Civil Engineering (CE)',)":"User.department“必须是”ValueError“实例
EN

Stack Overflow用户
提问于 2020-01-04 04:31:31
回答 2查看 99关注 0票数 1

我无法将数据插入数据库。我想创建一个具有特定部门名称和部门表的用户,并使用一个外键来检测来自某个部门的用户。

以下是我的模型文件:

代码语言:javascript
复制
class Department(models.Model):
name = models.CharField(max_length=100, blank=False, null=False)
admin_id = models.ForeignKey('Admin' , on_delete=models.CASCADE)
admin_post_id = models.ForeignKey('Admin_Post' , on_delete=models.CASCADE)

def __str__(self):
    return name

这是我的自定义用户模型:

代码语言:javascript
复制
class User(AbstractBaseUser):
      first_name = models.CharField(max_length=50, blank=False, null=False)
      last_name = models.CharField(max_length=50, blank=False, null=False)
      address = models.CharField(max_length=150)
      phone_number = models.IntegerField( blank=False, null=False, unique=True)
      department = models.ForeignKey('Department' , on_delete=models.CASCADE)
      semester = models.FloatField(blank=False, null=False)
      registation = models.IntegerField(blank=False, null=False, unique=True)
      email = models.EmailField(max_length=150, blank=False, null=False, unique=True)
      password = models.CharField(max_length=150, blank=False)
      password_con = models.CharField(max_length=150, blank=False, null=True)
      USERNAME_FIELD = 'email'
      REQUIRED_FIELD = ['email']
      objects = UserManager()
      def _str__(self):
         return registration;

以下是我的视图文件:

代码语言:javascript
复制
def register(request):
   if request.method == 'POST':
      first_name     = request.POST['first_name']
      last_name      = request.POST['last_name']
      address        = request.POST['address']
      phone_number   = request.POST['phone_number']
      department     = request.POST['department']
      semester       = request.POST['semester']
      registration    = request.POST['registration']
      email          = request.POST['email']
      password       = request.POST['password']
      password_con   = request.POST['password_con']
      user = Department()
      user = User.objects.create_user(first_name=first_name ,last_name=last_name ,address=address ,phone_number=phone_number ,department=department ,semester=semester ,registration=registration ,email=email ,password=password)
    if User.objects.filter(email=email).exists():
        messages.info(request,'Email is Already taken')
    elif User.objects.filter(registration=registration):
        messages.info(request,'Registration Id is Already taken')
    elif password != password_con:
        messages.info(request,'Credentials not mathcing')
    else:

        # user.department = Department.objects.get()
        user.save()
        print('user created')
        return redirect('signin/')
else:
    return render(request,'register.html')
EN

回答 2

Stack Overflow用户

发布于 2020-01-04 05:09:48

你的产品线

代码语言:javascript
复制
department     =    request.POST['department']

应该是这样的:

代码语言:javascript
复制
department     =    Department.objects.get(id=request.POST['department'])
票数 2
EN

Stack Overflow用户

发布于 2020-01-04 05:10:50

您正在尝试从名称中创建数据库关系,但在Django中无法做到这一点。您必须首先检索与POST数据相对应的Department实例,并赋予它,以便Django创建一个外键关系。

像这样的东西

代码语言:javascript
复制
# retrieve object
department_instance = Department.objects.get(name=request.POST['department']) # here 'Civil Engineering (CE)'
# use the instance (actually only the ID of that instance will be stored in the table User, but that's a detail)
User.objects.create_user(department=department_instance.id, etc...) #you can omit '.id'
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59584983

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档