News¶
Contents:
SQLObject 3.11.0¶
Features¶
- Continue working on
SQLRelatedJoinaliasing introduced in 3.10.2. When a table joins with itself callingrelJoinCol.filter(thisClass.q.column)raisesValueErrorhinting that an alias is required for filtering. - Test that
idTypeis eitherintorstr. - Added
sqlmeta.idSize. This sets the size of integer columnidfor MySQL and PostgreSQL. Allowed values are'TINY','SMALL','MEDIUM','BIG',None; default isNone. For Postgres mapped tosmallserial/serial/bigserial. For other backends it’s currently ignored. Feature request by Meet Gujrathi at https://stackoverflow.com/q/77360075/7976758
SQLObject 3.10.3¶
Released 2023 Oct 25.
Bug fixes¶
- Relaxed aliasing in
SQLRelatedJoinintroduced in 3.10.2 - aliasing is required only when the table joins with itself. When there’re two tables to join aliasing prevents filtering – wrong SQL is generated inrelJoinCol.filter(thisClass.q.column).
Drivers¶
Fix(SQLiteConnection): Release connections from threads that are no longer active. This fixes memory leak in multithreaded programs in Windows.
SQLiterequires different connections per thread soSQLiteConnectioncreates and stores a connection per thread. When a thread finishes its connections should be closed. But if a program doesn’t cooperate and doesn’t close connections at the end of a thread SQLObject leaks memory as connection objects are stuck inSQLiteConnection. On Linux the leak is negligible as Linux reuses thread IDs so new connections replace old ones and old connections are garbage collected. But Windows doesn’t reuse thread IDs so old connections pile and never released. To fix the problemSQLiteConnectionnow enumerates threads and releases connections from non-existing threads.Dropped
supersqlite. It seems abandoned. The last version 0.0.78 was released in 2018.
Tests¶
- Run tests with Python 3.12.
CI¶
GHActions: Ensure
piponly if neededThis is to work around a problem in conda with Python 3.7 - it brings in wrong version of
setuptoolsincompatible with Python 3.7.
SQLObject 3.10.2¶
Released 2023 Aug 09.
Minor features¶
- Class
Aliasgrows a method.select()to matchSQLObject.select().
Bug fixes¶
- Fixed a bug in
SQLRelatedJoinin the case where the table joins with itself; in the resulting SQL two instances of the table must use different aliases.
CI¶
- Install all Python and PyPy versions from
conda-forge.
SQLObject 3.10.1¶
Released 2022 Dec 22.
Minor features¶
- Use
module_loader.exec_module(module_loader.create_module())instead ofmodule_loader.load_module()when available.
Drivers¶
- Added
mysql-connector-python.
Tests¶
- Run tests with Python 3.11.
CI¶
- Ubuntu >= 22 and
setup-pythondropped Pythons < 3.7. Usecondavias-weigand/setup-condainstead ofsetup-pythonto install older Pythons on Linux.
SQLObject 3.10.0¶
Released 2022 Sep 20.
Features¶
- Allow connections in
ConnectionHubto be strings. This allows to open a new connection in every thread. - Add compatibility with
Pendulum.
Tests¶
- Run tests with Python 3.10.
CI¶
- GitHub Actions.
- Stop testing at Travis CI.
- Stop testing at AppVeyor.
Documentation¶
- DevGuide: source code must be pure ASCII.
- DevGuide:
reStructuredTextformat for docstrings is recommended. - DevGuide: de-facto good commit message format is required: subject/body/trailers.
- DevGuide:
conventional commitformat for commit message subject lines is recommended. - DevGuide:
Markdownformat for commit message bodies is recommended. - DevGuide: commit messages must be pure ASCII.