mirror of
				https://github.com/django/django.git
				synced 2025-10-25 14:46:09 +00:00 
			
		
		
		
	Added 1.1 release notes.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@11362 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		
							
								
								
									
										456
									
								
								docs/releases/1.1.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										456
									
								
								docs/releases/1.1.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,456 @@ | |||||||
|  | .. _releases-1.1: | ||||||
|  |  | ||||||
|  | ======================== | ||||||
|  | Django 1.1 release notes | ||||||
|  | ======================== | ||||||
|  |  | ||||||
|  | Welcome to Django 1.1! | ||||||
|  |  | ||||||
|  | Django 1.1 includes a number of nifty `new features`_, lots of bug | ||||||
|  | fixes, and an easy upgrade path from Django 1.0. | ||||||
|  |  | ||||||
|  | .. _new features: `What's new in Django 1.1`_ | ||||||
|  |  | ||||||
|  | Backwards-incompatible changes | ||||||
|  | ============================== | ||||||
|  |  | ||||||
|  | Django has a policy of :ref:`API stability <misc-api-stability>`. This means | ||||||
|  | that, in general, code you develop against Django 1.0 should continue to work | ||||||
|  | against 1.1 unchanged. However, we do sometimes make backwards-incompatible | ||||||
|  | changes if they're necessary to resolve bugs, and there are a handful of such | ||||||
|  | (minor) changes between Django 1.0 and Django 1.1.  | ||||||
|  |  | ||||||
|  | Before upgrading to Django 1.1 you should double-check that the following | ||||||
|  | changes don't impact you, and upgrade your code if they do. | ||||||
|  |  | ||||||
|  | Changes to constraint names | ||||||
|  | --------------------------- | ||||||
|  |  | ||||||
|  | Django 1.1 modifies the method used to generate database constraint names so | ||||||
|  | that names are consistent regardless of machine word size. This change is | ||||||
|  | backwards incompatible for some users. | ||||||
|  |  | ||||||
|  | If you are using a 32-bit platform, you're off the hook; you'll observe no | ||||||
|  | differences as a result of this change. | ||||||
|  |  | ||||||
|  | However, **users on 64-bit platforms may experience some problems** using the | ||||||
|  | :djadmin:`reset` management command. Prior to this change, 64-bit platforms | ||||||
|  | would generate a 64-bit, 16 character digest in the constraint name; for | ||||||
|  | example:: | ||||||
|  |  | ||||||
|  |     ALTER TABLE myapp_sometable ADD CONSTRAINT object_id_refs_id_5e8f10c132091d1e FOREIGN KEY ...  | ||||||
|  |      | ||||||
|  | Following this change, all platforms, regardless of word size, will generate a | ||||||
|  | 32-bit, 8 character digest in the constraint name; for example:: | ||||||
|  |  | ||||||
|  |     ALTER TABLE myapp_sometable ADD CONSTRAINT object_id_refs_id_32091d1e FOREIGN KEY ...  | ||||||
|  |  | ||||||
|  | As a result of this change, you will not be able to use the :djadmin:`reset` | ||||||
|  | management command on any table made by a 64-bit machine. This is because the | ||||||
|  | the new generated name will not match the historically generated name; as a | ||||||
|  | result, the SQL constructed by the reset command will be invalid. | ||||||
|  |  | ||||||
|  | If you need to reset an application that was created with 64-bit constraints, | ||||||
|  | you will need to manually drop the old constraint prior to invoking | ||||||
|  | :djadmin:`reset`. | ||||||
|  |  | ||||||
|  | Test cases are now run in a transaction | ||||||
|  | --------------------------------------- | ||||||
|  |  | ||||||
|  | Django 1.1 runs tests inside a transaction, allowing better test performance | ||||||
|  | (see `test performance improvements`_ for details). | ||||||
|  |  | ||||||
|  | This change is slightly backwards incompatible if existing tests need to test | ||||||
|  | transactional behavior, if they rely on invalid assumptions about the test | ||||||
|  | environment, or if they require a specific test case ordering. | ||||||
|  |  | ||||||
|  | For these cases, :class:`~django.test.TransactionTestCase` can be used instead. | ||||||
|  | This is a just a quick fix to get around test case errors revealed by the new | ||||||
|  | rollback approach; in the long-term tests should be rewritten to correct the | ||||||
|  | test case. | ||||||
|  |  | ||||||
|  | .. _removed-setremoteaddrfromforwardedfor-middleware: | ||||||
|  |  | ||||||
|  | Removed ``SetRemoteAddrFromForwardedFor`` middleware | ||||||
|  | ---------------------------------------------------- | ||||||
|  |  | ||||||
|  | For convenience, Django 1.0 included an optional middleware class -- | ||||||
|  | ``django.middleware.http.SetRemoteAddrFromForwardedFor`` -- which updated the | ||||||
|  | value of ``REMOTE_ADDR`` based on the HTTP ``X-Forwarded-For`` header commonly | ||||||
|  | set by some proxy configurations. | ||||||
|  |  | ||||||
|  | It has been demonstrated that this mechanism cannot be made reliable enough for | ||||||
|  | general-purpose use, and that (despite documentation to the contrary) its | ||||||
|  | inclusion in Django may lead application developers to assume that the value of | ||||||
|  | ``REMOTE_ADDR`` is "safe" or in some way reliable as a source of authentication. | ||||||
|  |  | ||||||
|  | While not directly a security issue, we've decided to remove this middleware | ||||||
|  | with the Django 1.1 release. It has been replaced with a class that does nothing | ||||||
|  | other than raise a ``DeprecationWarning``. | ||||||
|  |  | ||||||
|  | If you've been relying on this middleware, the easiest upgrade path is: | ||||||
|  |  | ||||||
|  |     * Examine `the code as it existed before it was removed`__. | ||||||
|  |      | ||||||
|  |     * Verify that it works correctly with your upstream proxy, modifying | ||||||
|  |       it to support your particular proxy (if necessary). | ||||||
|  |        | ||||||
|  |     * Introduce your modified version of ``SetRemoteAddrFromForwardedFor`` as a | ||||||
|  |       piece of middleware in your own project. | ||||||
|  |      | ||||||
|  | __ http://code.djangoproject.com/browser/django/trunk/django/middleware/http.py?rev=11000#L33 | ||||||
|  |  | ||||||
|  | Names of uploaded files are available later | ||||||
|  | ------------------------------------------- | ||||||
|  |  | ||||||
|  | .. currentmodule:: django.db.models | ||||||
|  |  | ||||||
|  | In Django 1.0, files uploaded and stored in a model's :class:`FileField` were | ||||||
|  | saved to disk before the model was saved to the database. This meant that the | ||||||
|  | actual file name assigned to the file was available before saving. For example, | ||||||
|  | it was available in a model's pre-save signal handler. | ||||||
|  |  | ||||||
|  | In Django 1.1 the file is saved as part of saving the model in the database, so | ||||||
|  | the actual file name used on disk cannot be relied on until *after* the model | ||||||
|  | has been saved saved. | ||||||
|  |  | ||||||
|  | Changes to how model formsets are saved | ||||||
|  | --------------------------------------- | ||||||
|  |  | ||||||
|  | .. currentmodule:: django.forms.models | ||||||
|  |  | ||||||
|  | In Django 1.1, :class:`BaseModelFormSet` now calls :meth:`ModelForm.save()`. | ||||||
|  |  | ||||||
|  | This is backwards-incompatible if you were modifying ``self.initial`` in a model | ||||||
|  | formset's ``__init__``, or if you relied on the internal ``_total_form_count`` | ||||||
|  | or ``_initial_form_count`` attributes of BaseFormSet. Those attributes are now | ||||||
|  | public methods. | ||||||
|  |  | ||||||
|  | Fixed the ``join`` filter's escaping behavior | ||||||
|  | --------------------------------------------- | ||||||
|  |  | ||||||
|  | The :ttag:`join` filter no longer escapes the literal value that is  | ||||||
|  | passed in for the connector.  | ||||||
|  |  | ||||||
|  | This is backwards incompatible for the special situation of the literal string | ||||||
|  | containing one of the five special HTML characters. Thus, if you were writing | ||||||
|  | ``{{ foo|join:"&" }}``, you now have to write ``{{ foo|join:"&" }}``. | ||||||
|  |  | ||||||
|  | The previous behavior was a bug and contrary to what was documented | ||||||
|  | and expected. | ||||||
|  |  | ||||||
|  | Permanent redirects and the ``redirect_to()`` generic view | ||||||
|  | ---------------------------------------------------------- | ||||||
|  |  | ||||||
|  | Django 1.1 adds a ``permanent`` argument to the | ||||||
|  | :func:`django.views.generic.simple.redirect_to()` view. This is technically | ||||||
|  | backwards-incompatible if you were using the ``redirect_to`` view with a | ||||||
|  | format-string key called 'permanent', which is highly unlikely. | ||||||
|  |  | ||||||
|  | Features deprecated in 1.1 | ||||||
|  | ========================== | ||||||
|  |  | ||||||
|  | One feature has been marked as deprecated in Django 1.1: | ||||||
|  |  | ||||||
|  |     * You should no longer use ``AdminSite.root()`` to register that admin | ||||||
|  |       views. That is, if your URLconf contains the line:: | ||||||
|  |        | ||||||
|  |             (r'^admin/(.*)', admin.site.root), | ||||||
|  |              | ||||||
|  |       You should change it to read:: | ||||||
|  |          | ||||||
|  |             (r'^admin/', include(admin.site.urls)), | ||||||
|  |              | ||||||
|  | You should begin to remove use of this features from your code immediately. | ||||||
|  |  | ||||||
|  | ``AdminSite.root`` will will raise a ``PendingDeprecationWarning`` if used in | ||||||
|  | Django 1.1. This warning is hidden by default. In Django 1.2, this warning will | ||||||
|  | be upgraded to a ``DeprecationWarning``, which will be displayed loudly. Django | ||||||
|  | 1.3 will remove ``AdminSite.root()`` entirely. | ||||||
|  |  | ||||||
|  | For more details on our deprecation policies and strategy, see | ||||||
|  | :ref:`internals-release-process`. | ||||||
|  |  | ||||||
|  | What's new in Django 1.1 | ||||||
|  | ======================== | ||||||
|  |  | ||||||
|  | Quite a bit: since Django 1.0, we've made 1,290 code commits, fixed 1,206 bugs, | ||||||
|  | and added roughly 10,000 lines of documentation. | ||||||
|  |  | ||||||
|  | The major new features in Django 1.1 are: | ||||||
|  |  | ||||||
|  | ORM improvements | ||||||
|  | ---------------- | ||||||
|  |  | ||||||
|  | .. currentmodule:: django.db.models | ||||||
|  |  | ||||||
|  | Two major enhancements have been added to Django's object-relational mapper | ||||||
|  | (ORM): aggregate support, and query expressions. | ||||||
|  |  | ||||||
|  | Aggregate support | ||||||
|  | ~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
|  | It's now possible to run SQL aggregate queries (i.e. ``COUNT()``, ``MAX()``, | ||||||
|  | ``MIN()``, etc.) from within Django's ORM. You can choose to either return the | ||||||
|  | results of the aggregate directly, or else annotate the objects in a | ||||||
|  | :class:`QuerySet` with the results of the aggregate query. | ||||||
|  |  | ||||||
|  | This feature is available as new :meth:`QuerySet.aggregate()`` and | ||||||
|  | :meth:`QuerySet.annotate()`` methods, and is covered in detail in :ref:`the ORM | ||||||
|  | aggregation documentation <topics-db-aggregation>`. | ||||||
|  |  | ||||||
|  | Query expressions | ||||||
|  | ~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
|  | Queries can now refer to a another field on the query and can traverse | ||||||
|  | relationships to refer to fields on related models. This is implemented in the | ||||||
|  | new :class:`F` object; for full details, including examples, consult the | ||||||
|  | :ref:`documentation for F expressions <query-expressions>`. | ||||||
|  |  | ||||||
|  | Model improvements | ||||||
|  | ------------------ | ||||||
|  |  | ||||||
|  | A number of features have been added to Django's model layer: | ||||||
|  |  | ||||||
|  | "Unmanaged" models | ||||||
|  | ~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
|  | You can now control whether or not Django manages the life-cycle of the database | ||||||
|  | tables for a model using the :attr:`~Options.managed` model option. This | ||||||
|  | defaults to ``True``, meaning that Django will create the appropriate database | ||||||
|  | tables in :djadmin:`syncdb` and remove them as part of the :djadmin:`reset` | ||||||
|  | command. That is, Django *manages* the database table's lifecycle. | ||||||
|  |  | ||||||
|  | If you set this to ``False``, however, no database table creating or deletion | ||||||
|  | will be automatically performed for this model. This is useful if the model | ||||||
|  | represents an existing table or a database view that has been created by some | ||||||
|  | other means. | ||||||
|  |  | ||||||
|  | For more details, see the documentation for the :attr:`~Options.managed` | ||||||
|  | option. | ||||||
|  |  | ||||||
|  | Proxy models | ||||||
|  | ~~~~~~~~~~~~ | ||||||
|  |  | ||||||
|  | You can now create :ref:`proxy models <proxy-models>`: subclasses of existing | ||||||
|  | models that only add Python-level (rather than database-level) behavior and | ||||||
|  | aren't represented by a new table. That is, the new model is a *proxy* for some | ||||||
|  | underlying model, which stores all the real data. | ||||||
|  |  | ||||||
|  | All the details can be found in the :ref:`proxy models documentation | ||||||
|  | <proxy-models>`. This feature is similar on the surface to unmanaged models, | ||||||
|  | so the documentation has an explanation of :ref:`how proxy models differ from | ||||||
|  | unmanaged models <proxy-vs-unmanaged-models>`. | ||||||
|  |  | ||||||
|  | Deferred fields | ||||||
|  | ~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
|  | In some complex situations, your models might contain fields which could | ||||||
|  | contain a lot of data (for example, large text fields), or require expensive | ||||||
|  | processing to convert them to Python objects. If you know you don't need those | ||||||
|  | particular fields, you can now tell Django not to retrieve them from the | ||||||
|  | database. | ||||||
|  |  | ||||||
|  | You'll do this with the :ref:`new queryset methods <queryset-defer>` | ||||||
|  | ``defer()`` and ``only()``. | ||||||
|  |  | ||||||
|  | Testing improvements | ||||||
|  | -------------------- | ||||||
|  |  | ||||||
|  | A few notable improvements have been made to the :ref:`testing framework | ||||||
|  | <topics-testing>`. | ||||||
|  |  | ||||||
|  | Test performance improvements | ||||||
|  | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
|  | .. currentmodule:: django.test | ||||||
|  |  | ||||||
|  | Tests written using Django's :ref:`testing framework <topics-testing>` now run | ||||||
|  | dramatically faster (as much as 10 times faster in many cases). | ||||||
|  |  | ||||||
|  | This was accomplished through the introduction of transaction-based tests: when | ||||||
|  | using :class:`django.test.TestCase`, your tests will now be run in a transaction | ||||||
|  | which is rolled back when finished, instead of by flushing and re-populating the | ||||||
|  | database. This results in an immense speedup for most types of unit tests. See | ||||||
|  | the documentation for :class:`TestCase` and :class:`TransactionTestCase` for a | ||||||
|  | full description, and some important notes on database support. | ||||||
|  |  | ||||||
|  | Test client improvements | ||||||
|  | ------------------------ | ||||||
|  |  | ||||||
|  | .. currentmodule:: django.test.client | ||||||
|  |  | ||||||
|  | A couple of small -- but highly useful -- improvements have been made to the | ||||||
|  | test client: | ||||||
|  |  | ||||||
|  |     * The test :class:`Client` now can automatically follow redirects with the | ||||||
|  |       ``follow`` argument to :meth:`Client.get` and :meth:`Client.post`. This | ||||||
|  |       makes testing views that issue redirects simpler. | ||||||
|  |        | ||||||
|  |     * It's now easier to get at the template context in the response returned | ||||||
|  |       the test client: you'll simply access the context as | ||||||
|  |       ``request.context[key]``. The old way, which treats ``request.context`` as | ||||||
|  |       a list of contexts, one for each rendered template in the inheritance | ||||||
|  |       chain, is still available if you need it. | ||||||
|  |  | ||||||
|  | New admin features | ||||||
|  | ------------------ | ||||||
|  |  | ||||||
|  | Django 1.1 adds a couple of nifty new features to Django's admin interface: | ||||||
|  |  | ||||||
|  | Editable fields on the change list | ||||||
|  | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
|  | You can now make fields editable on the admin list views via the new | ||||||
|  | :ref:`list_editable <admin-list-editable>` admin option. These fields will show | ||||||
|  | up as form widgets on the list pages, and can be edited and saved in bulk. | ||||||
|  |  | ||||||
|  | Admin "actions" | ||||||
|  | ~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
|  | You can now define :ref:`admin actions <ref-contrib-admin-actions>` that can | ||||||
|  | perform some action to a group of models in bulk. Users will be able to select | ||||||
|  | objects on the change list page and then apply these bulk actions to all | ||||||
|  | selected objects. | ||||||
|  |  | ||||||
|  | Django ships with one pre-defined admin action to delete a group of objects in | ||||||
|  | one fell swoop. | ||||||
|  |  | ||||||
|  | Conditional view processing | ||||||
|  | --------------------------- | ||||||
|  |  | ||||||
|  | Django now has much better support for :ref:`conditional view processing | ||||||
|  | <topics-conditional-processing>` using the standard ``ETag`` and | ||||||
|  | ``Last-Modified`` HTTP headers. This means you can now easily short-circuit | ||||||
|  | view processing by testing less-expensive conditions. For many views this can | ||||||
|  | lead to a serious improvement in speed and reduction in bandwidth. | ||||||
|  |  | ||||||
|  | URL namespaces | ||||||
|  | -------------- | ||||||
|  |  | ||||||
|  | Django 1.1 improves :ref:`named URL patterns <naming-url-patterns>` with the | ||||||
|  | introduction of URL "namespaces." | ||||||
|  |  | ||||||
|  | In short, this feature allows the same group of URLs, from the same application, | ||||||
|  | to be included in a Django URLConf multiple times, with varying (and potentially | ||||||
|  | nested) named prefixes which will be used when performing reverse resolution. In | ||||||
|  | other words, reusable applications like Django's admin interface may be | ||||||
|  | registered multiple times without URL conflicts. | ||||||
|  |  | ||||||
|  | For full details, see :ref:`the documentation on defining URL namespaces | ||||||
|  | <topics-http-defining-url-namespaces>`. | ||||||
|  |  | ||||||
|  | GeoDjango | ||||||
|  | --------- | ||||||
|  |  | ||||||
|  | In Django 1.1, GeoDjango_ (i.e. ``django.contrib.gis``) has several new | ||||||
|  | features: | ||||||
|  |  | ||||||
|  |     * Support for SpatiaLite_ -- a spatial database for SQLite -- as a spatial | ||||||
|  |       backend. | ||||||
|  |        | ||||||
|  |     * Geographic aggregates (``Collect``, ``Extent``, ``MakeLine``, ``Union``) | ||||||
|  |       and ``F`` expressions. | ||||||
|  |      | ||||||
|  |     * New ``GeoQuerySet`` methods: ``collect``, ``geojson``, and | ||||||
|  |       ``snap_to_grid``. | ||||||
|  |        | ||||||
|  |     * A new list interface methods for ``GEOSGeometry`` objects. | ||||||
|  |  | ||||||
|  | For more details, see the `GeoDjango documentation`_. | ||||||
|  |  | ||||||
|  | .. _geodjango: http://geodjango.org/ | ||||||
|  | .. _spatialite: http://www.gaia-gis.it/spatialite/ | ||||||
|  | .. _geodjango documentation: http://geodjango.org/docs/ | ||||||
|  |  | ||||||
|  | Other improvements | ||||||
|  | ------------------ | ||||||
|  |  | ||||||
|  | Other new features and changes introduced since Django 1.0 include: | ||||||
|  |  | ||||||
|  | * The :ref:`CSRF protection middleware <ref-contrib-csrf>` has been split into | ||||||
|  |   two classes -- ``CsrfViewMiddleware`` checks incoming requests, and | ||||||
|  |   ``CsrfResponseMiddleware`` processes outgoing responses. The combined | ||||||
|  |   ``CsrfMiddleware`` class (which does both) remains for | ||||||
|  |   backwards-compatibility, but using the split classes is now recommended in | ||||||
|  |   order to allow fine-grained control of when and where the CSRF processing | ||||||
|  |   takes place. | ||||||
|  |  | ||||||
|  | * :func:`~django.core.urlresolvers.reverse` and code which uses it (e.g., the | ||||||
|  |   ``{% url %}`` template tag) now works with URLs in Django's administrative | ||||||
|  |   site, provided that the admin URLs are set up via ``include(admin.site.urls)`` | ||||||
|  |   (sending admin requests to the ``admin.site.root`` view still works, but URLs | ||||||
|  |   in the admin will not be "reversible" when configured this way). | ||||||
|  |  | ||||||
|  | * The ``include()`` function in Django URLconf modules can now accept sequences | ||||||
|  |   of URL patterns (generated by ``patterns()``) in addition to module names. | ||||||
|  |  | ||||||
|  | * Instances of Django forms (see `the forms overview <topics-forms-index>`_ now | ||||||
|  |   have two additional methods, ``hidden_fields()`` and ``visible_fields()``, | ||||||
|  |   which return the list of hidden -- i.e., ``<input type="hidden">`` -- and | ||||||
|  |   visible fields on the form, respectively. | ||||||
|  |  | ||||||
|  | * The ``redirect_to`` generic view (see `the generic views documentation | ||||||
|  |   <ref-generic-views>`_) now accepts an additional keyword argument | ||||||
|  |   ``permanent``. If ``permanent`` is ``True``, the view will emit an HTTP | ||||||
|  |   permanent redirect (status code 301). If ``False``, the view will emit an HTTP | ||||||
|  |   temporary redirect (status code 302). | ||||||
|  |  | ||||||
|  | * A new database lookup type -- ``week_day`` -- has been added for ``DateField`` | ||||||
|  |   and ``DateTimeField``. This type of lookup accepts a number between 1 (Sunday) | ||||||
|  |   and 7 (Saturday), and returns objects where the field value matches that day | ||||||
|  |   of the week. See `the full list of lookup types <field-lookups>`_ for details. | ||||||
|  |  | ||||||
|  | * The ``{% for %}`` tag in Django's template language now accepts an optional | ||||||
|  |   ``{% empty %}`` clause, to be displayed when ``{% for %}`` is asked to loop | ||||||
|  |   over an empty sequence. See :ref:`the list of built-in template tags | ||||||
|  |   <ref-templates-builtins>` for examples of this. | ||||||
|  |  | ||||||
|  | * The :djadmin:`dumpdata` management command now accepts individual | ||||||
|  |   model names as arguments, allowing you to export the data just from | ||||||
|  |   particular models. | ||||||
|  |    | ||||||
|  | * There's a new :tfilter:`safeseq` template filter which works just like | ||||||
|  |   :tfilter:`safe` for lists, marking each item in the list as safe. | ||||||
|  |    | ||||||
|  | * :ref:`Cache backends <topics-cache>` now support ``incr()`` and | ||||||
|  |   ``decr()`` commands to increment and decrement the value of a cache key. | ||||||
|  |   On cache backends that support atomic increment/decrement -- most | ||||||
|  |   notably, the memcached backend -- these operations will be atomic, and | ||||||
|  |   quite fast. | ||||||
|  |    | ||||||
|  | * Django now can :ref:`easily delegate authentication to the web server | ||||||
|  |   <howto-auth-remote-user>` via a new authentication backend that supports | ||||||
|  |   the standard ``REMOTE_USER`` environment variable used for this purpose. | ||||||
|  |    | ||||||
|  | * There's a new :func:`django.shortcuts.redirect` function that makes it | ||||||
|  |   easier to issue redirects given an object, a view name, or a URL. | ||||||
|  |    | ||||||
|  | * The ``postgresql_psycopg2`` backend now supports :ref:`native PostgreSQL | ||||||
|  |   autocommit <postgresql-notes>`. This is an advanced, PostgreSQL-specific | ||||||
|  |   feature, that can make certain read-heavy applications a good deal | ||||||
|  |   faster. | ||||||
|  |  | ||||||
|  | What's next? | ||||||
|  | ============ | ||||||
|  |  | ||||||
|  | We'll take a short break, and then work on Django 1.2 will begin -- no rest for | ||||||
|  | the weary! If you'd like to help, discussion of Django development, including | ||||||
|  | progress toward the 1.2 release, takes place daily on the django-developers | ||||||
|  | mailing list: | ||||||
|  |  | ||||||
|  |     * http://groups.google.com/group/django-developers | ||||||
|  |  | ||||||
|  | ... and in the ``#django-dev`` IRC channel on ``irc.freenode.net``. Feel free to | ||||||
|  | join the discussions! | ||||||
|  |  | ||||||
|  | Django's online documentation also includes pointers on how to contribute to | ||||||
|  | Django:  | ||||||
|  |  | ||||||
|  |     * :ref:`How to contribute to Django <internals-contributing>` | ||||||
|  |  | ||||||
|  | Contributions on any level -- developing code, writing documentation or simply | ||||||
|  | triaging tickets and helping to test proposed bugfixes -- are always welcome and | ||||||
|  | appreciated. | ||||||
|  |  | ||||||
|  | And that's the way it is. | ||||||
| @@ -22,6 +22,7 @@ changes made in that version. | |||||||
|    1.1-alpha-1 |    1.1-alpha-1 | ||||||
|    1.1-beta-1 |    1.1-beta-1 | ||||||
|    1.1-rc-1 |    1.1-rc-1 | ||||||
|  |    1.1 | ||||||
|  |  | ||||||
| .. seealso:: | .. seealso:: | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user