StuffHappens
StuffHappens

Reputation: 6557

Django EmbeddedField raises ValidationError because of renamed field

I've got a Django application with djongo as a database driver. The models are:

class Blog(models.Model):
    _id = models.ObjectIdField()
    name = models.CharField(max_length=100, db_column="Name")
    tagline = models.TextField()

class Entry(models.Model):
    _id = models.ObjectIdField()
    blog = models.EmbeddedField(
        model_container=Blog
    )

When I run this application, I got an error:

File "\.venv\lib\site-packages\djongo\models\fields.py", line 125, in _validate_container
    raise ValidationError(
django.core.exceptions.ValidationError: ['Field "m.Blog.name"  of model container:"<class \'project.m.models.Blog\'>" cannot be named as "name", different from column name "Name"']

I want to keep the name of the field name in my model and database different because the database already exists, and I can't change it. The database uses camelCase for naming fields, whereas in the application, I want to use snake_case.

How to avoid this error?

Upvotes: 7

Views: 251

Answers (4)

Anee Mes
Anee Mes

Reputation: 54

The error you're getting is due to Djongo trying to validate the field name as in the model and Name as created in the database. You can specify for Djongo to not validate the fields of the model container by setting validate=False in the EmbeddedField. Modify your Entry model as:

class Entry(models.Model):
    _id = models.ObjectIdField()
    blog = models.EmbeddedField(
        model_container=Blog, validate=False
    )

This should fix your error.

Upvotes: 2

dheeraj
dheeraj

Reputation: 43

you might need to do manage.py makemigrations and manage.py migrate

Upvotes: 1

007Coding
007Coding

Reputation: 42

try this:

class Blog(models.Model):
    _id = models.ObjectIdField()
    name = models.CharField(max_length=100, db_column="BlogName")
    tagline = models.TextField()

or this

class Blog(models.Model):
    _id = models.ObjectIdField()
    BlogName = models.CharField(max_length=100, db_column="name")
    tagline = models.TextField()

When you use the "db_colum" parameter, you must choose a different name, even if it is lowercase or uppercase

Upvotes: 1

user18426886
user18426886

Reputation:

I think it should be db_column instead of bd_column so:

class Blog(models.Model):
    _id = models.ObjectIdField()
    name = models.CharField(max_length=100, db_column="Name")
    tagline = models.TextField()

Upvotes: 0

Related Questions