Skip to main content

This django Migration Operation can be used to transfer a fields default value to the database scheme.

Project description

Django Add Default Value

Django Migration Operation that can be used to transfer a field's default value to the database scheme.

PyPi License Contributing 3yourminD-Careers Stars

Dependencies

  • MySQL (or compatible)
  • PostgreSQL
  • Microsoft SQL Server

Installation

pip install django-add-default-value

You can then use AddDefaultValue in your migration file to transfer the default values to your database. Afterwards, it's just the usual ./manage.py migrate.

Usage

Add this manually to a autogenerated Migration, that adds a new field::

AddDefaultValue(
    model_name='my_model',
    name='my_field',
    value='my_default'
)

Example

Given the following migration::

operations = [
    migrations.AddField(
        field=models.CharField(default='my_default', max_length=255),
        model_name='my_model',
        name='my_field',
    ),
]

Modify the migration to add a default value::

+from django_add_default_value import AddDefaultValue
+
 operations = [
     migrations.AddField(
         field=models.CharField(default='my_default', max_length=255),
         model_name='my_model',
         name='my_field',
     ),
+    AddDefaultValue(
+        model_name='my_model',
+        name='my_field',
+        value='my_default'
+    )
 ]

If you check python manage.py sqlmigrate [app name] [migration], you will see that the default value now gets set.

Contributing

First of all, thank you very much for contributing to this project. Please base your work on the master branch and target master in your pull request.

There are a few packages needed on the host system. For ubuntu the following commands will install these

apt-get install freetds-dev unixodbc-dev tdsodbc

Then add the following text to /etc/odbcinst.ini:

[FreeTDS]
Description=FreeTDS unixODBC Driver
Driver=/usr/lib/x86_64-linux-gnu/odbc/libtdsodbc.so
Setup=/usr/lib/x86_64-linux-gnu/odbc/libtdsS.so

To succesfully use the dbshell management command (very useful for debugging), the client binaries for the respective database engines are needed.

Then install pipenv. Edit the Pipfile to select your Django version and the accompanying MS-SQL driver. Make sure you don't commit this change in any pull request - we always set it to the oldest supported version.

Once you've updated the Pipfile, run pipenv install --python 3 --dev. You should now have a working development environment as a virtualenv. To access it, run pipenv shell or prefix commands with pipenv run. For more information see the pipenv documentation.

Testing

Copy the relevant sample settings file in test_project to the file without .sample in it. Adjust the values to match your environment (or match your environment to the values).

You should now be able to run the tests using tox. Select your environment when needed, using the -e command line flag. See Tox's excellent documentation.

Roadmap

  • 0.1: Better and maintainable packaging
  • 0.3: Tests work with tox. Supported platforms / versions frozen
  • 0.5: Solid tests integrated with Travis or similar CI pipeline
  • 0.9: Final API changes preparing for 1.0
  • 1.0: API freeze

License

django-add-default-value is released under the Apache 2.0 License.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django-add-default-value-0.3.2.tar.gz (6.7 kB view details)

Uploaded Source

Built Distribution

File details

Details for the file django-add-default-value-0.3.2.tar.gz.

File metadata

  • Download URL: django-add-default-value-0.3.2.tar.gz
  • Upload date:
  • Size: 6.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.4.2 requests/2.20.0 setuptools/40.7.2 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.7.4

File hashes

Hashes for django-add-default-value-0.3.2.tar.gz
Algorithm Hash digest
SHA256 07203848b48370a4327d04bd64a26c0034933168038b55ce436abbb756945bc6
MD5 dad52df7e588d373862578b29ef4ffa9
BLAKE2b-256 1064fb4a58e206ab9a5e6ad408ed26d13cc95f5bcf19ebe2ae520e79ab48d1ae

See more details on using hashes here.

File details

Details for the file django_add_default_value-0.3.2-py3-none-any.whl.

File metadata

  • Download URL: django_add_default_value-0.3.2-py3-none-any.whl
  • Upload date:
  • Size: 7.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.4.2 requests/2.20.0 setuptools/40.7.2 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.7.4

File hashes

Hashes for django_add_default_value-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 d866def8bfdc288c2fe94a17ca57c9d97b569b881da10102eea330952e19636c
MD5 79552e2f6689970ac638ba0101ebf2c3
BLAKE2b-256 d1a7a7eb6d37c51b8b027d5e973244d7c8b6f72c804d045d913bb42c2ed4a4a8

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page