Skip to content

Releases: coleifer/peewee

3.6.4

07 Aug 21:32
Compare
Choose a tag to compare

Take a whole new approach, following what simplejson does. Allow the build_ext command class to fail, and retry without extensions in the event we run into issues building extensions. References #1676.

View commits

3.6.3

18 Jul 16:36
Compare
Choose a tag to compare

Add check in setup.py to determine if a C compiler is available before building C extensions. References #1676.

View commits

3.6.2

18 Jul 15:22
Compare
Choose a tag to compare

Use ctypes.util.find_library to determine if libsqlite3 is installed. Should fix problems people are encountering installing when SQLite3 is not available (issue #1676).

View commits

3.6.1

17 Jul 21:32
Compare
Choose a tag to compare

Fixed an issue in setup.py when Cython is not installed.

3.6.0

17 Jul 21:09
Compare
Choose a tag to compare
  • Support for Python 3.7, including bugfixes related to new StopIteration handling inside of generators.
  • Support for specifying ROWS or RANGE window frame types. For more information, see the new frame type documentation.
  • Add APIs for user-defined window functions if using pysqlite3 and sqlite 3.25.0 or newer.
  • TimestampField now uses 64-bit integer data-type for storage.
  • Added support to pwiz and playhouse.reflection to enable generating models from VIEWs.
  • Added lower-level database API for introspecting VIEWs.
  • Revamped continuous integration setup for better coverage, including 3.7 and 3.8-dev.
  • Allow building C extensions even if Cython is not installed, by distributing pre-generated C source files.
  • Switch to using setuptools for packaging.

View commits

3.5.2

03 Jul 21:13
Compare
Choose a tag to compare
  • New guide to using window functions in Peewee.
  • New and improved table name auto-generation. This feature is not backwards compatible, so it is disabled by default. To enable, set legacy_table_names=False in your model's Meta options. For more details, see table names documentation.
  • Allow passing single fields/columns to window function order_by and partition_by arguments.
  • Support for FILTER (WHERE...) clauses with window functions and aggregates.
  • Added IdentityField class suitable for use with Postgres 10's new identity column type. It can be used anywhere AutoField or BigAutoField was being used previously.
  • Fixed bug creating indexes on tables that are in attached databases (SQLite).
  • Fixed obscure bug when using prefetch() and ModelAlias to populate a back-reference related model.

View commits

3.5.1

27 Jun 15:33
Compare
Choose a tag to compare

New features

  • New documentation for working with relationships in Peewee.
  • Improved tests and documentation for MySQL upsert functionality.
  • Allow database parameter to be specified with ModelSelect.get() method. For discussion, see #1620.
  • Add QualifiedNames helper to peewee module exports.
  • Add temporary= meta option to support temporary tables.
  • Allow a Database object to be passed to constructor of DataSet helper.

Bug fixes

  • Fixed edge-case where attempting to alias a field to it's underlying column-name (when different), Peewee would not respect the alias and use the field name instead. See #1625 for details and discussion.
  • Raise a ValueError when joining and aliasing the join to a foreign-key's object_id_name descriptor. Should prevent accidentally introducing O(n) queries or silently ignoring data from a joined-instance.
  • Fixed bug for MySQL when creating a foreign-key to a model which used the BigAutoField for it's primary-key.
  • Fixed bugs in the implementation of user-defined aggregates and extensions with the APSW SQLite driver.
  • Fixed regression introduced in 3.5.0 which ignored custom Model __repr__().
  • Fixed regression from 2.x in which inserting from a query using a SQL() was no longer working. Refs #1645.

View commits

3.5.0

29 May 20:37
Compare
Choose a tag to compare

Backwards-incompatible changes

  • Custom Model repr no longer use the convention of overriding __unicode__, and now use __str__.
  • Redesigned the sqlite json1 integration. and changed some of the APIs and semantics of various JSONField methods. The documentation has been expanded to include more examples and the API has been simplified to make it easier to work with. These changes do not have any effect on the Postgresql JSON fields.

New features

  • Better default repr for model classes and fields.
  • ForeignKeyField() accepts a new initialization parameter, deferrable, for specifying when constraints should be enforced.
  • BitField.flag() can be called without a value parameter for the common use-case of using flags that are powers-of-2.
  • SqliteDatabase pragmas can be specified as a dict (previously required a list of 2-tuples).
  • SQLite TableFunction (docs) will print Python exception tracebacks raised in the initialize and iterate callbacks, making debugging significantly easier.

Bug fixes

  • Fixed bug in migrator.add_column() where, if the field being added declared a non-standard index type (e.g., binary json field with GIN index), this index type was not being respected.
  • Fixed bug in database.table_exists() where the implementation did not match the documentation. Implementation has been updated to match the documentation.
  • Fixed bug in SQLite TableFunction implementation which raised errors if the return value of the iterate() method was not a tuple.

View commits

3.4.0

20 May 03:57
Compare
Choose a tag to compare

Backwards-incompatible changes

  • The regexp() operation is now case-sensitive for MySQL and Postgres. To perform case-insensitive regexp operations, use iregexp().
  • The SQLite BareField() field-type now supports all column constraints except specifying the data-type. Previously it silently ignored any column constraints.
  • LIMIT and OFFSET parameters are now treated as parameterized values instead of literals.
  • The schema parameter for SQLite database introspection methods is no longer ignored by default. The schema corresponds to the name given to an attached database.
  • ArrayField now accepts a new parameter field_kwargs, which is used to pass information to the array field's field_class initializer.

New features and other changes

  • SQLite backup interface supports specifying page-counts and a user-defined progress handler.
  • GIL is released when doing backups or during SQLite busy timeouts (when using the peewee SQLite busy-handler).
  • Add NATURAL join-type to the JOIN helper.
  • Improved identifier quoting to allow specifying distinct open/close-quote characters. Enables adding support for MSSQL, for instance, which uses square brackets, e.g. [table].[column].
  • Unify timeout interfaces for SQLite databases (use seconds everywhere rather than mixing seconds and milliseconds, which was confusing).
  • Added attach() and detach() methods to SQLite database, making it possible to attach additional databases (e.g. an in-memory cache db).

View commits

3.3.4

04 May 14:01
Compare
Choose a tag to compare
  • Added a BinaryUUIDField class for efficiently storing UUIDs in 16-bytes.
  • Fix dataset's update_cache() logic so that when updating a single table that was newly-added, we also ensure that all dependent tables are updated at the same time. Refs coleifer/sqlite-web#42.

View commits