In one of the model i have set one timestamp field as follows:
created_datetime = models.DateTimeField(auto_now_add = True)
While in shell i am able to create a obj and save it, however in my application it is raising a exception that created_datetime field cannot be null.
Confused where things went wrong!! How to reslove it.
I had this and it really confused me for ages.
Turned out that my model had a custom primary key, and it was due to a bug not setting it when constructing some test objects.
The first time this worked fine as
auto_now_add
setcreated_at
. The second time it didn't as the object with a null primary key already existed, so it was doing an update. And it tried to set that tocreated_at
null, which wasn't allowed in my model.So worth checking if you end up on this question with the error "in my application it is raising a exception that created_datetime field cannot be null", that that could be caused by not setting a primary key correctly.
The solution was for me to correctly set a primary key.
You can do something like this
As far as I know, best practice for default datetimes is to use the following:
Don't forget to import datetime
The following way is in the "part1" of django documentation