diff options
| author | Adrian Holovaty <adrian@holovaty.com> | 2006-05-22 03:01:02 +0000 |
|---|---|---|
| committer | Adrian Holovaty <adrian@holovaty.com> | 2006-05-22 03:01:02 +0000 |
| commit | 0fc2a2c1a891a9729f99b550bca6334e97c0dce3 (patch) | |
| tree | 3155ce410af625fb3e0ce9a94e4ff0d4ea41a6bf /docs/model-api.txt | |
| parent | be57a7fd1a743672fb4bd682950674aa6823190d (diff) | |
Added 'Overriding default model methods' section to model-api.txt
git-svn-id: http://code.djangoproject.com/svn/django/trunk@2955 bcc190cf-cafb-0310-a4f2-bffc1f526a37
Diffstat (limited to 'docs/model-api.txt')
| -rw-r--r-- | docs/model-api.txt | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/docs/model-api.txt b/docs/model-api.txt index 6ceabf4e3d..15192fcbb7 100644 --- a/docs/model-api.txt +++ b/docs/model-api.txt @@ -1599,6 +1599,39 @@ API. See `Other lookup options`_. .. _Python DB-API: http://www.python.org/peps/pep-0249.html .. _Other lookup options: http://www.djangoproject.com/documentation/db_api/#extra-params-select-where-tables +Overriding default model methods +-------------------------------- + +As explained in the `database API docs`_, each model gets a few methods +automatically -- most notably, ``save()`` and ``delete()``. You can override +these methods to alter behavior. + +A classic use-case for overriding the built-in methods is if you want something +to happen whenever you save an object. For example:: + + class Blog(models.Model): + name = models.CharField(maxlength=100) + tagline = models.TextField() + + def save(self): + do_something() + super(Blog, self).save() # Call the "real" save() method. + do_something_else() + +You can also prevent saving:: + + class Blog(models.Model): + name = models.CharField(maxlength=100) + tagline = models.TextField() + + def save(self): + if self.name == "Yoko Ono's blog": + return # Yoko shall never have her own blog! + else: + super(Blog, self).save() # Call the "real" save() method. + +.. _database API docs: http://www.djangoproject.com/documentation/db_api/ + Models across files =================== |
