Go to file
Manuel Francisco Naranjo 5e1b11acb7
Merge pull request #8 from squio/patch-1
Update README.rst
2021-05-01 08:50:20 +02:00
dbview Don't migrate disallowed connections 2021-04-12 19:16:29 -07:00
.gitignore change package version and fix some error 2020-05-27 16:06:30 +08:00
LICENSE Initial commit 2015-07-27 15:50:27 -03:00
MANIFEST.in Readme and other minor updates. 2020-11-20 13:45:31 +08:00
README.rst Update README.rst 2021-03-02 14:09:03 +01:00
setup.py Readme and other minor updates. 2020-11-20 13:45:31 +08:00

README.rst

####################
django-database-view
####################

A simple pluggable application that allows to work with database views.

Quick start
===========

1. Install the package::

    pip install django-database-view

2. In your ``models.py`` create classes which extend ``dbview.models.DbView``
   like this:

   .. code-block:: python

      from django.db import models
      from dbview.models import DbView

      class ModelA(models.Model):
          fielda = models.CharField()
          fieldc = models.IntegerField()

      class MyView(DbView):
          fieldA = models.OneToOneField(ModelA, primary_key=True,
              db_column='fielda__id')
          fieldB = models.IntegerField(blank=True, null=True, db_column='fieldb')

          @classmethod
          def view(cls):
              """
              This method returns the SQL string that creates the view,
              in this example fieldB is the result of annotating another column
              """
              qs = modelA.objects.all(
              ).annotate(
                  fieldb=models.Sum('fieldc'),
              ).annotate(
                  fielda__id=models.F('pk'),
              ).order_by(
                  'fielda__id',
              ).values(
                  'fielda__id',
                  'fieldb',
              )
              return str(qs.query)

   Alternatively ``get_view_str`` method could be used to write a custom SQL:

   .. code-block:: python

       class MyView(DbView):
           # ...

           @classmethod
           def get_view_str(cls):
               return """
                   CREATE VIEW my_view AS (
                   SELECT ...
               )"""

3. Then create a migration point for your view generation, edit that
   migration and modify it, add:
   ``from dbview.helpers import CreateView`` and replace the line the
   call to ``migrations.CreateModel`` with ``CreateView``.

4. Migrate your database and start using your database views.