Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Discussion: deprecation of execute_many() and fetch_many() on prepared statement interfaces and potential replacement #3108

Open
abonander opened this issue Mar 12, 2024 · 6 comments
Labels
db:sqlite Related to SQLite enhancement New feature or request

Comments

@abonander
Copy link
Collaborator

abonander commented Mar 12, 2024

#3007 (released in 0.7.4) deprecates execute_many() and fetch_many() in the query*() family of functions. These functions were meant to allow executing a single query string containing multiple SQL statements while still using bind parameters. These will be removed in 0.8.0.

This is because only SQLite ever supported this feature, due to the idiosyncrasy of its prepared statement interface being the primary way to execute SQL against a database. All other databases forbid multiple statements in one string when using prepared statements as a defense against SQL injection. Thus, it's extremely confusing to have such methods as part of a database-agnostic API. And, it was never supported by the query*!() macros because it was unclear what they should return when processing a query string with multiple statements.

To support multiple queries in one prepared statement for arbitrary database backends would require parsing the string to find ; delimiters, prepare it as multiple statements, and then execute them in an implicit transaction. Doing this much behind the scenes would be antithetical to the design of SQLx. The SQLite driver had to implement this to support migrations in line with the other drivers, but sqlite3_prepare() in the C API is explicitly designed to incrementally parse a single query string into multiple statements for this exact reason, so we at least don't have to parse SQL ourselves.

The raw_sql API added in #3007 includes the ability to execute multiple statements in one query string, with the caveat that bind parameters cannot be used (as they require the prepared statement interface).

If anyone needs to be able to execute multiple query statements in one string, with bind parameters, using the SQLite driver, this issue is open to discuss what that API should look like. Supporting this in other drivers that have similar support in their prepared statement interfaces is an option, but supporting for databases like Postgres which don't is out of scope. Be prepared to explain why you cannot work around this by explicitly executing multiple statements in a transaction.

This issue will be closed at the conclusion of the next release cycle (0.8.x) if no one responds to it by then, under the assumption that no one had a problem with the deprecation and removal of the aforementioned APIs.

@abonander abonander added enhancement New feature or request db:sqlite Related to SQLite labels Mar 12, 2024
@abonander abonander changed the title Discussion: deprecation of execute_many() and fetch_many() on prepared statement interfaces Discussion: deprecation of execute_many() and fetch_many() on prepared statement interfaces and potential replacement Mar 12, 2024
@francois-random
Copy link

francois-random commented Mar 25, 2024

Hello, I'm currently using fetch_many with mysql to detect multiple resultsets returned by a single call to a stored procedure.
I don't see other ways to deal with multiple resultsets in the public interface of sqlx, but it seems important to keep a similar function (with a different name if you think it's better).
In the following example, there are 3 different resultsets (the second resultset has two rows), that I can detect with Either::Left.

delimiter $
CREATE PROCEDURE my_proc(IN value INTEGER)
Sp:BEGIN
    SELECT value;
    SELECT 7*value UNION SELECT value*value;
    SELECT value*value, 7*value, value*value;
END$
delimiter ;
    let rows = sqlx::query("call my_proc(10);").fetch_many(db_executor);
    while let Some(either) = rows.try_next().await? {
        match either {
            Either::Left(result) => {
                // new resultset
            }
            Either::Right(row) => {
                // new row
            }
        }
    }

@francois-random
Copy link

Just saying that perhaps at the origin fetch_many and exec_many meant many resultsets, not many statements

@genusistimelord
Copy link
Contributor

I do find myself looking for a good solution for a execute many and i felt the stream and such kind-of turned me away from using the current functions. So i ended up splitting my code into parts to execute separately. Though to me I think it would be more Efficient to be able to have some sort of Raw API that can Build separate scripts and execute them and return them for you, For the systems that don't support multiple. Or to allow ways to Execute multiples without binds would be fine as well as normally I only do this for data that I don't need to worry about SQL injection's. If we do add such an ability we need to Comment on them letting people know these are acceptable to SQL injection attacks if used improperly.

For things like Creating Tables and all the types to go along with the tables would be better done in a single Execution versus splitting them up which shouldn't need prepared statements to function. Would also be nice if the end user only had to deal with a Vec of returns from these multiple scripts in a single execution. however, either way is fine as long as we have good examples.

@abonander
Copy link
Collaborator Author

I'm not against retaining some sort of abstraction for this, the biggest issue is it doesn't seem to belong on the Executor trait because it doesn't apply to all databases. Postgres really doesn't have an equivalent, for example.

Even MySQL vs SQLite, the semantics differ somewhat. MySQL, one query can return multiple results whereas SQLite it's one result set per query but you can have multiple queries in one string. It seems weird to have both of those covered by the same abstraction.

I'm not hostile to the use cases presented here, but I also have no idea what the right answer is.

@genusistimelord
Copy link
Contributor

I think it would be fine to move this into something higher than the Executor. As then you can handle the way each thing works across all the databases supported. It would be much easier to maintain then at least. Maybe have some sort of Preparer Trait and Type that can do the splitting or combining based on the database and Execute them using the correct Executor functions. doing this could also allow binder buildings across multiple sets. At least with a Preparer Level we can answer for the different abstractions and let the end user know how it works per database. were in the extractor itself we shouldnt do this.

@eirnym
Copy link

eirnym commented May 1, 2024

In other languages/frameworks fetch_many is a standard name for fetching query results in batches (for streaming purposes), while execute_many is dedicated to run many queries at once. The only suggested application for execute_many I've met was many INSERT queries. Thus naming for fetch function is not obvious for a programmer from other languages.

AsyncPG (Python async driver for binary protocol for PostgreSQL) somewhat deprecates execute_many, as binary data takes less space and nobody should do additional encoding/decoding from/into a string

montekki referenced this issue in matter-labs/zksync-withdrawal-finalizer May 2, 2024
[![Mend
Renovate](https://app.renovatebot.com/images/banner.svg)](https://renovatebot.com)

This PR contains the following updates:

| Package | Type | Update | Change |
|---|---|---|---|
| [sqlx](https://github.com/launchbadge/sqlx) | workspace.dependencies
| patch | `0.7` -> `0.7.4` |

---

### Release Notes

<details>
<summary>launchbadge/sqlx (sqlx)</summary>

###
[`v0.7.4`](https://github.com/launchbadge/sqlx/blob/HEAD/CHANGELOG.md#074---2024-03-11)

[Compare
Source](https://github.com/launchbadge/sqlx/compare/v0.7.3...v0.7.4)

38 pull requests were merged this release cycle.

This is officially the **last** release of the 0.7.x release cycle.

As of this release, development of 0.8.0 has begun on `main` and only
high-priority bugfixes may be backported.

##### Added

- \[[#&#8203;2891]]: feat: expose getters for connect options fields
\[\[[@&#8203;saiintbrisson](https://github.com/saiintbrisson)]]
- \[[#&#8203;2902]]: feat: add `to_url_lossy` to connect options
\[\[[@&#8203;lily-mosquitoes](https://github.com/lily-mosquitoes)]]
- \[[#&#8203;2927]]: Support `query!` for cargo-free systems
\[\[[@&#8203;kshramt](https://github.com/kshramt)]]
- \[[#&#8203;2997]]: doc(FAQ): add entry explaining prepared statements
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;3001]]: Update README to clarify MariaDB support
\[\[[@&#8203;iangilfillan](https://github.com/iangilfillan)]]
- \[[#&#8203;3004]]: feat(logging): Add numeric elapsed time field
elapsed_secs \[\[[@&#8203;iamjpotts](https://github.com/iamjpotts)]]
- \[[#&#8203;3007]]: feat: add `raw_sql` API
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- This hopefully makes it easier to find how to execute statements which
are not supported by the default
        prepared statement interfaces `query*()` and `query!()`.
- Improved documentation across the board for the `query*()` functions.
- Deprecated: `execute_many()` and `fetch_many()` on interfaces that use
prepared statements.
- Multiple SQL statements in one query string were only supported by
SQLite because its prepared statement
interface is the *only* way to execute SQL. All other database flavors
forbid multiple statements in
one prepared statement string as an extra defense against SQL injection.
- The new `raw_sql` API retains this functionality because it explicitly
does *not* use prepared statements.
Raw or text-mode query interfaces generally allow multiple statements in
one query string, and this is
supported by all current databases. Due to their nature, however, one
cannot use bind parameters with them.
- If this change affects you, an issue is open for discussion:
[https://github.com/launchbadge/sqlx/issues/3108](https://github.com/launchbadge/sqlx/issues/3108)
- \[[#&#8203;3011]]: Added support to IpAddr with MySQL/MariaDB.
\[\[[@&#8203;Icerath](https://github.com/Icerath)]]
- \[[#&#8203;3013]]: Add default implementation for PgInterval
\[\[[@&#8203;pawurb](https://github.com/pawurb)]]
- \[[#&#8203;3018]]: Add default implementation for PgMoney
\[\[[@&#8203;pawurb](https://github.com/pawurb)]]
- \[[#&#8203;3026]]: Update docs to reflect support for MariaDB data
types \[\[[@&#8203;iangilfillan](https://github.com/iangilfillan)]]
- \[[#&#8203;3037]]: feat(mysql): allow to connect with mysql driver
without default behavor
\[\[[@&#8203;darkecho731](https://github.com/darkecho731)]]

##### Changed

- \[[#&#8203;2900]]: Show latest url to docs for macro.migrate
\[\[[@&#8203;Vrajs16](https://github.com/Vrajs16)]]
- \[[#&#8203;2914]]: Use `create_new` instead of `atomic-file-write`
\[\[[@&#8203;mattfbacon](https://github.com/mattfbacon)]]
- \[[#&#8203;2926]]: docs: update example for `PgConnectOptions`
\[\[[@&#8203;Fyko](https://github.com/Fyko)]]
- \[[#&#8203;2989]]: sqlx-core: Remove dotenvy dependency
\[\[[@&#8203;joshtriplett](https://github.com/joshtriplett)]]
- \[[#&#8203;2996]]: chore: Update ahash to 0.8.7
\[\[[@&#8203;takenoko-gohan](https://github.com/takenoko-gohan)]]
- \[[#&#8203;3006]]: chore(deps): Replace unmaintained tempdir crate
with tempfile \[\[[@&#8203;iamjpotts](https://github.com/iamjpotts)]]
- \[[#&#8203;3008]]: chore: Ignore .sqlx folder created by running ci
steps locally \[\[[@&#8203;iamjpotts](https://github.com/iamjpotts)]]
- \[[#&#8203;3009]]: chore(dev-deps): Upgrade env_logger from 0.9 to
0.11 \[\[[@&#8203;iamjpotts](https://github.com/iamjpotts)]]
- \[[#&#8203;3010]]: chore(deps): Upgrade criterion to 0.5.1
\[\[[@&#8203;iamjpotts](https://github.com/iamjpotts)]]
- \[[#&#8203;3050]]: Optimize SASL auth in sqlx-postgres
\[\[[@&#8203;mirek26](https://github.com/mirek26)]]
- \[[#&#8203;3055]]: Set TCP_NODELAY option on TCP sockets
\[\[[@&#8203;mirek26](https://github.com/mirek26)]]
- \[[#&#8203;3065]]: Improve max_lifetime handling
\[\[[@&#8203;mirek26](https://github.com/mirek26)]]
- \[[#&#8203;3072]]: Change the name of "inner" function generated by
`#[sqlx::test]` \[\[[@&#8203;ciffelia](https://github.com/ciffelia)]]
- \[[#&#8203;3083]]: Remove sha1 because it's not being used in postgres
\[\[[@&#8203;rafaelGuerreiro](https://github.com/rafaelGuerreiro)]]

##### Fixed

- \[[#&#8203;2898]]: Fixed docs
\[\[[@&#8203;Vrajs16](https://github.com/Vrajs16)]]
- \[[#&#8203;2905]]: fix(mysql): Close prepared statement if persistence
is disabled
\[\[[@&#8203;larsschumacher](https://github.com/larsschumacher)]]
- \[[#&#8203;2913]]: Fix handling of deferred constraints
\[\[[@&#8203;Thomasdezeeuw](https://github.com/Thomasdezeeuw)]]
- \[[#&#8203;2919]]: fix duplicate "\`" in FromRow "default" attribute
doc comment \[\[[@&#8203;shengsheng](https://github.com/shengsheng)]]
- \[[#&#8203;2932]]: fix(postgres): avoid unnecessary flush in
PgCopyIn::read_from \[\[[@&#8203;tsing](https://github.com/tsing)]]
- \[[#&#8203;2955]]: Minor fixes
\[\[[@&#8203;Dawsoncodes](https://github.com/Dawsoncodes)]]
- \[[#&#8203;2963]]: Fixed ReadMe badge styling
\[\[[@&#8203;tadghh](https://github.com/tadghh)]]
- \[[#&#8203;2976]]: fix: AnyRow not support PgType::Varchar
\[\[[@&#8203;holicc](https://github.com/holicc)]]
- \[[#&#8203;3053]]: fix: do not panic when binding a large BigDecimal
\[\[[@&#8203;Ekleog](https://github.com/Ekleog)]]
- \[[#&#8203;3056]]: fix: spans in sqlite tracing
([#&#8203;2876](https://github.com/launchbadge/sqlx/issues/2876))
\[\[[@&#8203;zoomiti](https://github.com/zoomiti)]]
- \[[#&#8203;3089]]: fix(migrate): improve error message when parsing
version from filename
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;3098]]: Migrations fixes
\[\[[@&#8203;abonander](https://github.com/abonander)]]
    -   Unhides `sqlx::migrate::Migrator`.
- Improves I/O error message when failing to read a file in
`migrate!()`.

[#&#8203;2891]: https://github.com/launchbadge/sqlx/pull/2891

[#&#8203;2898]: https://github.com/launchbadge/sqlx/pull/2898

[#&#8203;2900]: https://github.com/launchbadge/sqlx/pull/2900

[#&#8203;2902]: https://github.com/launchbadge/sqlx/pull/2902

[#&#8203;2905]: https://github.com/launchbadge/sqlx/pull/2905

[#&#8203;2913]: https://github.com/launchbadge/sqlx/pull/2913

[#&#8203;2914]: https://github.com/launchbadge/sqlx/pull/2914

[#&#8203;2919]: https://github.com/launchbadge/sqlx/pull/2919

[#&#8203;2926]: https://github.com/launchbadge/sqlx/pull/2926

[#&#8203;2927]: https://github.com/launchbadge/sqlx/pull/2927

[#&#8203;2932]: https://github.com/launchbadge/sqlx/pull/2932

[#&#8203;2955]: https://github.com/launchbadge/sqlx/pull/2955

[#&#8203;2963]: https://github.com/launchbadge/sqlx/pull/2963

[#&#8203;2976]: https://github.com/launchbadge/sqlx/pull/2976

[#&#8203;2989]: https://github.com/launchbadge/sqlx/pull/2989

[#&#8203;2996]: https://github.com/launchbadge/sqlx/pull/2996

[#&#8203;2997]: https://github.com/launchbadge/sqlx/pull/2997

[#&#8203;3001]: https://github.com/launchbadge/sqlx/pull/3001

[#&#8203;3004]: https://github.com/launchbadge/sqlx/pull/3004

[#&#8203;3006]: https://github.com/launchbadge/sqlx/pull/3006

[#&#8203;3007]: https://github.com/launchbadge/sqlx/pull/3007

[#&#8203;3008]: https://github.com/launchbadge/sqlx/pull/3008

[#&#8203;3009]: https://github.com/launchbadge/sqlx/pull/3009

[#&#8203;3010]: https://github.com/launchbadge/sqlx/pull/3010

[#&#8203;3011]: https://github.com/launchbadge/sqlx/pull/3011

[#&#8203;3013]: https://github.com/launchbadge/sqlx/pull/3013

[#&#8203;3018]: https://github.com/launchbadge/sqlx/pull/3018

[#&#8203;3026]: https://github.com/launchbadge/sqlx/pull/3026

[#&#8203;3037]: https://github.com/launchbadge/sqlx/pull/3037

[#&#8203;3050]: https://github.com/launchbadge/sqlx/pull/3050

[#&#8203;3053]: https://github.com/launchbadge/sqlx/pull/3053

[#&#8203;3055]: https://github.com/launchbadge/sqlx/pull/3055

[#&#8203;3056]: https://github.com/launchbadge/sqlx/pull/3056

[#&#8203;3065]: https://github.com/launchbadge/sqlx/pull/3065

[#&#8203;3072]: https://github.com/launchbadge/sqlx/pull/3072

[#&#8203;3083]: https://github.com/launchbadge/sqlx/pull/3083

[#&#8203;3089]: https://github.com/launchbadge/sqlx/pull/3089

[#&#8203;3098]: https://github.com/launchbadge/sqlx/pull/3098

###
[`v0.7.3`](https://github.com/launchbadge/sqlx/blob/HEAD/CHANGELOG.md#073---2023-11-22)

38 pull requests were merged this release cycle.

##### Added

- \[[#&#8203;2478]]: feat(citext): support postgres citext
\[\[[@&#8203;hgranthorner](https://github.com/hgranthorner)]]
- \[[#&#8203;2545]]: Add `fixtures_path` in sqlx::test args
\[\[[@&#8203;ripa1995](https://github.com/ripa1995)]]
- \[[#&#8203;2665]]: feat(mysql): support packet splitting
\[\[[@&#8203;tk2217](https://github.com/tk2217)]]
- \[[#&#8203;2752]]: Enhancement
[#&#8203;2747](https://github.com/launchbadge/sqlx/issues/2747)
Provide `fn PgConnectOptions::get_host(&self)`
\[\[[@&#8203;boris-lok](https://github.com/boris-lok)]]
- \[[#&#8203;2769]]: Customize the macro error message based on the
metadata \[\[[@&#8203;Nemo157](https://github.com/Nemo157)]]
- \[[#&#8203;2793]]: derived Hash trait for PgInterval
\[\[[@&#8203;yasamoka](https://github.com/yasamoka)]]
- \[[#&#8203;2801]]: derive FromRow: sqlx(default) for all fields
\[\[[@&#8203;grgi](https://github.com/grgi)]]
- \[[#&#8203;2827]]: Add impl `FromRow` for the unit type
\[\[[@&#8203;nanoqsh](https://github.com/nanoqsh)]]
- \[[#&#8203;2871]]: Add `MySqlConnectOptions::get_database()`
\[\[[@&#8203;shiftrightonce](https://github.com/shiftrightonce)]]
- \[[#&#8203;2873]]: Sqlx Cli: Added force flag to drop database for
postgres \[\[[@&#8203;Vrajs16](https://github.com/Vrajs16)]]
- \[[#&#8203;2894]]: feat: `Text` adapter
\[\[[@&#8203;abonander](https://github.com/abonander)]]

##### Changed

- \[[#&#8203;2701]]: Remove documentation on offline feature
\[\[[@&#8203;Baptistemontan](https://github.com/Baptistemontan)]]
- \[[#&#8203;2713]]: Add additional info regarding using Transaction and
PoolConnection as…
\[\[[@&#8203;satwanjyu](https://github.com/satwanjyu)]]
- \[[#&#8203;2770]]: Update README.md
\[\[[@&#8203;snspinn](https://github.com/snspinn)]]
- \[[#&#8203;2797]]: doc(mysql): document behavior regarding `BOOLEAN`
and the query macros
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;2803]]: Don't use separate temp dir for query jsons (2)
\[\[[@&#8203;mattfbacon](https://github.com/mattfbacon)]]
- \[[#&#8203;2819]]: postgres begin cancel safe
\[\[[@&#8203;conradludgate](https://github.com/conradludgate)]]
- \[[#&#8203;2832]]: Update extra_float_digits default to 2 instead of 3
\[\[[@&#8203;brianheineman](https://github.com/brianheineman)]]
- \[[#&#8203;2865]]: Update Faq - Bulk upsert with optional fields
\[\[[@&#8203;Vrajs16](https://github.com/Vrajs16)]]
- \[[#&#8203;2880]]: feat: use specific message for slow query logs
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;2882]]: Do not require db url for prepare
\[\[[@&#8203;tamasfe](https://github.com/tamasfe)]]
- \[[#&#8203;2890]]: doc(sqlite): cover lack of `NUMERIC` support
\[\[[@&#8203;abonander](https://github.com/abonander)]]
-   \[No PR]: Upgraded `libsqlite3-sys` to 0.27.0
    -   Note: linkage to `libsqlite3-sys` is considered semver-exempt;
        see the release notes for 0.7.0 below for details.

##### Fixed

- \[[#&#8203;2640]]: fix: sqlx::macro db cleanup race condition by
adding a margin to current timestamp
\[\[[@&#8203;fhsgoncalves](https://github.com/fhsgoncalves)]]
- \[[#&#8203;2655]]: \[fix] Urlencode when passing filenames to sqlite3
\[\[[@&#8203;uttarayan21](https://github.com/uttarayan21)]]
- \[[#&#8203;2684]]: Make PgListener recover from UnexpectedEof
\[\[[@&#8203;hamiltop](https://github.com/hamiltop)]]
- \[[#&#8203;2688]]: fix: Make rust_decimal and bigdecimal decoding more
lenient \[\[[@&#8203;cameronbraid](https://github.com/cameronbraid)]]
- \[[#&#8203;2754]]: Is tests/x.py maintained? And I tried fix it.
\[\[[@&#8203;qwerty2501](https://github.com/qwerty2501)]]
- \[[#&#8203;2784]]: fix: decode postgres time without subsecond
\[\[[@&#8203;granddaifuku](https://github.com/granddaifuku)]]
- \[[#&#8203;2806]]: Depend on version of async-std with non-private
spawn-blocking \[\[[@&#8203;A248](https://github.com/A248)]]
- \[[#&#8203;2820]]: fix: correct decoding of `rust_decimal::Decimal`
for high-precision values
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;2822]]: issue
[#&#8203;2821](https://github.com/launchbadge/sqlx/issues/2821) Update
error handling logic when opening a TCP connection
\[\[[@&#8203;anupj](https://github.com/anupj)]]
- \[[#&#8203;2826]]: chore: bump some sqlx-core dependencies
\[\[[@&#8203;djc](https://github.com/djc)]]
- \[[#&#8203;2838]]: Fixes rust_decimal scale for Postgres
\[\[[@&#8203;jkleinknox](https://github.com/jkleinknox)]]
- \[[#&#8203;2847]]: Fix comment in `sqlx migrate add` help text
\[\[[@&#8203;cryeprecision](https://github.com/cryeprecision)]]
- \[[#&#8203;2850]]: fix(core): avoid unncessary wakeups in
`try_stream!()`
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;2856]]: Prevent warnings running `cargo build`
\[\[[@&#8203;nyurik](https://github.com/nyurik)]]
- \[[#&#8203;2864]]: fix(sqlite): use `AtomicUsize` for thread IDs
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;2892]]: Fixed force dropping bug
\[\[[@&#8203;Vrajs16](https://github.com/Vrajs16)]]

[#&#8203;2478]: https://github.com/launchbadge/sqlx/pull/2478

[#&#8203;2545]: https://github.com/launchbadge/sqlx/pull/2545

[#&#8203;2640]: https://github.com/launchbadge/sqlx/pull/2640

[#&#8203;2655]: https://github.com/launchbadge/sqlx/pull/2655

[#&#8203;2665]: https://github.com/launchbadge/sqlx/pull/2665

[#&#8203;2684]: https://github.com/launchbadge/sqlx/pull/2684

[#&#8203;2688]: https://github.com/launchbadge/sqlx/pull/2688

[#&#8203;2701]: https://github.com/launchbadge/sqlx/pull/2701

[#&#8203;2713]: https://github.com/launchbadge/sqlx/pull/2713

[#&#8203;2752]: https://github.com/launchbadge/sqlx/pull/2752

[#&#8203;2754]: https://github.com/launchbadge/sqlx/pull/2754

[#&#8203;2769]: https://github.com/launchbadge/sqlx/pull/2769

[#&#8203;2770]: https://github.com/launchbadge/sqlx/pull/2770

[#&#8203;2782]: https://github.com/launchbadge/sqlx/pull/2782

[#&#8203;2784]: https://github.com/launchbadge/sqlx/pull/2784

[#&#8203;2793]: https://github.com/launchbadge/sqlx/pull/2793

[#&#8203;2797]: https://github.com/launchbadge/sqlx/pull/2797

[#&#8203;2801]: https://github.com/launchbadge/sqlx/pull/2801

[#&#8203;2803]: https://github.com/launchbadge/sqlx/pull/2803

[#&#8203;2806]: https://github.com/launchbadge/sqlx/pull/2806

[#&#8203;2819]: https://github.com/launchbadge/sqlx/pull/2819

[#&#8203;2820]: https://github.com/launchbadge/sqlx/pull/2820

[#&#8203;2822]: https://github.com/launchbadge/sqlx/pull/2822

[#&#8203;2826]: https://github.com/launchbadge/sqlx/pull/2826

[#&#8203;2827]: https://github.com/launchbadge/sqlx/pull/2827

[#&#8203;2832]: https://github.com/launchbadge/sqlx/pull/2832

[#&#8203;2838]: https://github.com/launchbadge/sqlx/pull/2838

[#&#8203;2847]: https://github.com/launchbadge/sqlx/pull/2847

[#&#8203;2850]: https://github.com/launchbadge/sqlx/pull/2850

[#&#8203;2856]: https://github.com/launchbadge/sqlx/pull/2856

[#&#8203;2864]: https://github.com/launchbadge/sqlx/pull/2864

[#&#8203;2865]: https://github.com/launchbadge/sqlx/pull/2865

[#&#8203;2871]: https://github.com/launchbadge/sqlx/pull/2871

[#&#8203;2873]: https://github.com/launchbadge/sqlx/pull/2873

[#&#8203;2880]: https://github.com/launchbadge/sqlx/pull/2880

[#&#8203;2882]: https://github.com/launchbadge/sqlx/pull/2882

[#&#8203;2890]: https://github.com/launchbadge/sqlx/pull/2890

[#&#8203;2892]: https://github.com/launchbadge/sqlx/pull/2892

[#&#8203;2894]: https://github.com/launchbadge/sqlx/pull/2894

###
[`v0.7.2`](https://github.com/launchbadge/sqlx/blob/HEAD/CHANGELOG.md#072---2023-09-25)

23 pull requests were merged this release cycle.

##### Added

- \[[#&#8203;2121]]: Add JSON support to `FromRow` derive
\[\[[@&#8203;95ulisse](https://github.com/95ulisse)]]
- \[[#&#8203;2533]]: Implement mysql_clear_password
\[\[[@&#8203;ldanilek](https://github.com/ldanilek)]]
- \[[#&#8203;2538]]: cli: add --target-version CLI flags for migrate
run/revert \[\[[@&#8203;inahga](https://github.com/inahga)]]
- \[[#&#8203;2577]]: supplement Postgres listen example with a small
chat example \[\[[@&#8203;JockeM](https://github.com/JockeM)]]
- \[[#&#8203;2602]]: Support naming migrations sequentially
\[\[[@&#8203;vmax](https://github.com/vmax)]]
- \[[#&#8203;2634]]: Adding PgHasArrayType for &\[u8;N]
\[\[[@&#8203;snf](https://github.com/snf)]]
- \[[#&#8203;2646]]: Support for setting client certificate and key from
bytes \[\[[@&#8203;wyhaya](https://github.com/wyhaya)]]
- \[[#&#8203;2664]]: Automatically infer migration type
\[\[[@&#8203;vmax](https://github.com/vmax)]]
- \[[#&#8203;2712]]: Add impl for `Type`, `Decode`, and `Encode` for
`Box<str>` and `Box<[u8]>`
\[\[[@&#8203;grant0417](https://github.com/grant0417)]]

##### Changed

- \[[#&#8203;2650]]: Cleanup format arguments
\[\[[@&#8203;nyurik](https://github.com/nyurik)]]
- \[[#&#8203;2695]]: remove \&mut PoolConnection from Executor docs
\[\[[@&#8203;olback](https://github.com/olback)]]
    -   This impl was removed in 0.7.0 because of coherence issues.
- \[[#&#8203;2706]]: Clarify where optional features should be enabled
\[\[[@&#8203;kryptan](https://github.com/kryptan)]]
- \[[#&#8203;2717]]: Update README.md
\[\[[@&#8203;fermanjj](https://github.com/fermanjj)]]
- \[[#&#8203;2739]]: Bump mariadb CI images + mysql unpin
\[\[[@&#8203;grooverdan](https://github.com/grooverdan)]]
- \[[#&#8203;2742]]: Implemented poll_flush for Box\<S:Socket>
\[\[[@&#8203;bobozaur](https://github.com/bobozaur)]]
- \[[#&#8203;2740]]: Remove sealed trait comments from documentation
\[\[[@&#8203;bobozaur](https://github.com/bobozaur)]]
- \[[#&#8203;2750]]: Fix
[#&#8203;2384](https://github.com/launchbadge/sqlx/issues/2384), bump
flume to v0.11.0 \[\[[@&#8203;madadam](https://github.com/madadam)]]
- \[[#&#8203;2757]]: Remove unused `remove_dir_all` crate from
`sqlx-cli`, fixes RUSTSEC-2023-0018
\[\[[@&#8203;aldur](https://github.com/aldur)]]

##### Fixed

- \[[#&#8203;2624]]: Documentation typo: BYTE -> BINARY
\[\[[@&#8203;sebastianv89](https://github.com/sebastianv89)]]
- \[[#&#8203;2628]]: docs: 0.7 is stable in the entire README
\[\[[@&#8203;marcusirgens](https://github.com/marcusirgens)]]
- \[[#&#8203;2630]]: fix(postgres): fix buffer management in
PgCopyIn::read_from \[\[[@&#8203;tsing](https://github.com/tsing)]]
- \[[#&#8203;2651]]: Chore: Fix few build warnings, and make CI fail on
warn \[\[[@&#8203;nyurik](https://github.com/nyurik)]]
- \[[#&#8203;2670]]: fix: ignore extra fields in Postgres describe
parsing \[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;2687]]: docs: Fix description of `min_connections`
\[\[[@&#8203;hakoerber](https://github.com/hakoerber)]]

[#&#8203;2121]: https://github.com/launchbadge/sqlx/pull/2121

[#&#8203;2533]: https://github.com/launchbadge/sqlx/pull/2533

[#&#8203;2538]: https://github.com/launchbadge/sqlx/pull/2538

[#&#8203;2577]: https://github.com/launchbadge/sqlx/pull/2577

[#&#8203;2602]: https://github.com/launchbadge/sqlx/pull/2602

[#&#8203;2624]: https://github.com/launchbadge/sqlx/pull/2624

[#&#8203;2628]: https://github.com/launchbadge/sqlx/pull/2628

[#&#8203;2630]: https://github.com/launchbadge/sqlx/pull/2630

[#&#8203;2634]: https://github.com/launchbadge/sqlx/pull/2634

[#&#8203;2646]: https://github.com/launchbadge/sqlx/pull/2646

[#&#8203;2650]: https://github.com/launchbadge/sqlx/pull/2650

[#&#8203;2651]: https://github.com/launchbadge/sqlx/pull/2651

[#&#8203;2664]: https://github.com/launchbadge/sqlx/pull/2664

[#&#8203;2670]: https://github.com/launchbadge/sqlx/pull/2670

[#&#8203;2687]: https://github.com/launchbadge/sqlx/pull/2687

[#&#8203;2695]: https://github.com/launchbadge/sqlx/pull/2695

[#&#8203;2706]: https://github.com/launchbadge/sqlx/pull/2706

[#&#8203;2712]: https://github.com/launchbadge/sqlx/pull/2712

[#&#8203;2717]: https://github.com/launchbadge/sqlx/pull/2717

[#&#8203;2739]: https://github.com/launchbadge/sqlx/pull/2739

[#&#8203;2740]: https://github.com/launchbadge/sqlx/pull/2740

[#&#8203;2742]: https://github.com/launchbadge/sqlx/pull/2742

[#&#8203;2750]: https://github.com/launchbadge/sqlx/pull/2750

[#&#8203;2757]: https://github.com/launchbadge/sqlx/pull/2757

</details>

---

### Configuration

📅 **Schedule**: Branch creation - At any time (no schedule defined),
Automerge - At any time (no schedule defined).

🚦 **Automerge**: Disabled by config. Please merge this manually once you
are satisfied.

♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the
rebase/retry checkbox.

🔕 **Ignore**: Close this PR and you won't be reminded about this update
again.

---

- [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check
this box

---

This PR has been generated by [Mend
Renovate](https://www.mend.io/free-developer-tools/renovate/). View
repository job log
[here](https://developer.mend.io/github/matter-labs/zksync-withdrawal-finalizer).

<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzNy4zMzEuMCIsInVwZGF0ZWRJblZlciI6IjM3LjMzMS4wIiwidGFyZ2V0QnJhbmNoIjoibWFpbiIsImxhYmVscyI6W119-->

Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
renovate bot referenced this issue in SebastianGoeb/kindle-to-anki May 3, 2024
[![Mend
Renovate](https://app.renovatebot.com/images/banner.svg)](https://renovatebot.com)

This PR contains the following updates:

| Package | Type | Update | Change |
|---|---|---|---|
| [sqlx](https://github.com/launchbadge/sqlx) | dependencies | patch |
`0.7` -> `0.7.4` |

---

### Release Notes

<details>
<summary>launchbadge/sqlx (sqlx)</summary>

###
[`v0.7.4`](https://github.com/launchbadge/sqlx/blob/HEAD/CHANGELOG.md#074---2024-03-11)

[Compare
Source](https://github.com/launchbadge/sqlx/compare/v0.7.3...v0.7.4)

38 pull requests were merged this release cycle.

This is officially the **last** release of the 0.7.x release cycle.

As of this release, development of 0.8.0 has begun on `main` and only
high-priority bugfixes may be backported.

##### Added

- \[[#&#8203;2891]]: feat: expose getters for connect options fields
\[\[[@&#8203;saiintbrisson](https://github.com/saiintbrisson)]]
- \[[#&#8203;2902]]: feat: add `to_url_lossy` to connect options
\[\[[@&#8203;lily-mosquitoes](https://github.com/lily-mosquitoes)]]
- \[[#&#8203;2927]]: Support `query!` for cargo-free systems
\[\[[@&#8203;kshramt](https://github.com/kshramt)]]
- \[[#&#8203;2997]]: doc(FAQ): add entry explaining prepared statements
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;3001]]: Update README to clarify MariaDB support
\[\[[@&#8203;iangilfillan](https://github.com/iangilfillan)]]
- \[[#&#8203;3004]]: feat(logging): Add numeric elapsed time field
elapsed_secs \[\[[@&#8203;iamjpotts](https://github.com/iamjpotts)]]
- \[[#&#8203;3007]]: feat: add `raw_sql` API
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- This hopefully makes it easier to find how to execute statements which
are not supported by the default
        prepared statement interfaces `query*()` and `query!()`.
- Improved documentation across the board for the `query*()` functions.
- Deprecated: `execute_many()` and `fetch_many()` on interfaces that use
prepared statements.
- Multiple SQL statements in one query string were only supported by
SQLite because its prepared statement
interface is the *only* way to execute SQL. All other database flavors
forbid multiple statements in
one prepared statement string as an extra defense against SQL injection.
- The new `raw_sql` API retains this functionality because it explicitly
does *not* use prepared statements.
Raw or text-mode query interfaces generally allow multiple statements in
one query string, and this is
supported by all current databases. Due to their nature, however, one
cannot use bind parameters with them.
- If this change affects you, an issue is open for discussion:
[https://github.com/launchbadge/sqlx/issues/3108](https://github.com/launchbadge/sqlx/issues/3108)
- \[[#&#8203;3011]]: Added support to IpAddr with MySQL/MariaDB.
\[\[[@&#8203;Icerath](https://github.com/Icerath)]]
- \[[#&#8203;3013]]: Add default implementation for PgInterval
\[\[[@&#8203;pawurb](https://github.com/pawurb)]]
- \[[#&#8203;3018]]: Add default implementation for PgMoney
\[\[[@&#8203;pawurb](https://github.com/pawurb)]]
- \[[#&#8203;3026]]: Update docs to reflect support for MariaDB data
types \[\[[@&#8203;iangilfillan](https://github.com/iangilfillan)]]
- \[[#&#8203;3037]]: feat(mysql): allow to connect with mysql driver
without default behavor
\[\[[@&#8203;darkecho731](https://github.com/darkecho731)]]

##### Changed

- \[[#&#8203;2900]]: Show latest url to docs for macro.migrate
\[\[[@&#8203;Vrajs16](https://github.com/Vrajs16)]]
- \[[#&#8203;2914]]: Use `create_new` instead of `atomic-file-write`
\[\[[@&#8203;mattfbacon](https://github.com/mattfbacon)]]
- \[[#&#8203;2926]]: docs: update example for `PgConnectOptions`
\[\[[@&#8203;Fyko](https://github.com/Fyko)]]
- \[[#&#8203;2989]]: sqlx-core: Remove dotenvy dependency
\[\[[@&#8203;joshtriplett](https://github.com/joshtriplett)]]
- \[[#&#8203;2996]]: chore: Update ahash to 0.8.7
\[\[[@&#8203;takenoko-gohan](https://github.com/takenoko-gohan)]]
- \[[#&#8203;3006]]: chore(deps): Replace unmaintained tempdir crate
with tempfile \[\[[@&#8203;iamjpotts](https://github.com/iamjpotts)]]
- \[[#&#8203;3008]]: chore: Ignore .sqlx folder created by running ci
steps locally \[\[[@&#8203;iamjpotts](https://github.com/iamjpotts)]]
- \[[#&#8203;3009]]: chore(dev-deps): Upgrade env_logger from 0.9 to
0.11 \[\[[@&#8203;iamjpotts](https://github.com/iamjpotts)]]
- \[[#&#8203;3010]]: chore(deps): Upgrade criterion to 0.5.1
\[\[[@&#8203;iamjpotts](https://github.com/iamjpotts)]]
- \[[#&#8203;3050]]: Optimize SASL auth in sqlx-postgres
\[\[[@&#8203;mirek26](https://github.com/mirek26)]]
- \[[#&#8203;3055]]: Set TCP_NODELAY option on TCP sockets
\[\[[@&#8203;mirek26](https://github.com/mirek26)]]
- \[[#&#8203;3065]]: Improve max_lifetime handling
\[\[[@&#8203;mirek26](https://github.com/mirek26)]]
- \[[#&#8203;3072]]: Change the name of "inner" function generated by
`#[sqlx::test]` \[\[[@&#8203;ciffelia](https://github.com/ciffelia)]]
- \[[#&#8203;3083]]: Remove sha1 because it's not being used in postgres
\[\[[@&#8203;rafaelGuerreiro](https://github.com/rafaelGuerreiro)]]

##### Fixed

- \[[#&#8203;2898]]: Fixed docs
\[\[[@&#8203;Vrajs16](https://github.com/Vrajs16)]]
- \[[#&#8203;2905]]: fix(mysql): Close prepared statement if persistence
is disabled
\[\[[@&#8203;larsschumacher](https://github.com/larsschumacher)]]
- \[[#&#8203;2913]]: Fix handling of deferred constraints
\[\[[@&#8203;Thomasdezeeuw](https://github.com/Thomasdezeeuw)]]
- \[[#&#8203;2919]]: fix duplicate "\`" in FromRow "default" attribute
doc comment \[\[[@&#8203;shengsheng](https://github.com/shengsheng)]]
- \[[#&#8203;2932]]: fix(postgres): avoid unnecessary flush in
PgCopyIn::read_from \[\[[@&#8203;tsing](https://github.com/tsing)]]
- \[[#&#8203;2955]]: Minor fixes
\[\[[@&#8203;Dawsoncodes](https://github.com/Dawsoncodes)]]
- \[[#&#8203;2963]]: Fixed ReadMe badge styling
\[\[[@&#8203;tadghh](https://github.com/tadghh)]]
- \[[#&#8203;2976]]: fix: AnyRow not support PgType::Varchar
\[\[[@&#8203;holicc](https://github.com/holicc)]]
- \[[#&#8203;3053]]: fix: do not panic when binding a large BigDecimal
\[\[[@&#8203;Ekleog](https://github.com/Ekleog)]]
- \[[#&#8203;3056]]: fix: spans in sqlite tracing
([#&#8203;2876](https://github.com/launchbadge/sqlx/issues/2876))
\[\[[@&#8203;zoomiti](https://github.com/zoomiti)]]
- \[[#&#8203;3089]]: fix(migrate): improve error message when parsing
version from filename
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;3098]]: Migrations fixes
\[\[[@&#8203;abonander](https://github.com/abonander)]]
    -   Unhides `sqlx::migrate::Migrator`.
- Improves I/O error message when failing to read a file in
`migrate!()`.

[#&#8203;2891]: https://github.com/launchbadge/sqlx/pull/2891

[#&#8203;2898]: https://github.com/launchbadge/sqlx/pull/2898

[#&#8203;2900]: https://github.com/launchbadge/sqlx/pull/2900

[#&#8203;2902]: https://github.com/launchbadge/sqlx/pull/2902

[#&#8203;2905]: https://github.com/launchbadge/sqlx/pull/2905

[#&#8203;2913]: https://github.com/launchbadge/sqlx/pull/2913

[#&#8203;2914]: https://github.com/launchbadge/sqlx/pull/2914

[#&#8203;2919]: https://github.com/launchbadge/sqlx/pull/2919

[#&#8203;2926]: https://github.com/launchbadge/sqlx/pull/2926

[#&#8203;2927]: https://github.com/launchbadge/sqlx/pull/2927

[#&#8203;2932]: https://github.com/launchbadge/sqlx/pull/2932

[#&#8203;2955]: https://github.com/launchbadge/sqlx/pull/2955

[#&#8203;2963]: https://github.com/launchbadge/sqlx/pull/2963

[#&#8203;2976]: https://github.com/launchbadge/sqlx/pull/2976

[#&#8203;2989]: https://github.com/launchbadge/sqlx/pull/2989

[#&#8203;2996]: https://github.com/launchbadge/sqlx/pull/2996

[#&#8203;2997]: https://github.com/launchbadge/sqlx/pull/2997

[#&#8203;3001]: https://github.com/launchbadge/sqlx/pull/3001

[#&#8203;3004]: https://github.com/launchbadge/sqlx/pull/3004

[#&#8203;3006]: https://github.com/launchbadge/sqlx/pull/3006

[#&#8203;3007]: https://github.com/launchbadge/sqlx/pull/3007

[#&#8203;3008]: https://github.com/launchbadge/sqlx/pull/3008

[#&#8203;3009]: https://github.com/launchbadge/sqlx/pull/3009

[#&#8203;3010]: https://github.com/launchbadge/sqlx/pull/3010

[#&#8203;3011]: https://github.com/launchbadge/sqlx/pull/3011

[#&#8203;3013]: https://github.com/launchbadge/sqlx/pull/3013

[#&#8203;3018]: https://github.com/launchbadge/sqlx/pull/3018

[#&#8203;3026]: https://github.com/launchbadge/sqlx/pull/3026

[#&#8203;3037]: https://github.com/launchbadge/sqlx/pull/3037

[#&#8203;3050]: https://github.com/launchbadge/sqlx/pull/3050

[#&#8203;3053]: https://github.com/launchbadge/sqlx/pull/3053

[#&#8203;3055]: https://github.com/launchbadge/sqlx/pull/3055

[#&#8203;3056]: https://github.com/launchbadge/sqlx/pull/3056

[#&#8203;3065]: https://github.com/launchbadge/sqlx/pull/3065

[#&#8203;3072]: https://github.com/launchbadge/sqlx/pull/3072

[#&#8203;3083]: https://github.com/launchbadge/sqlx/pull/3083

[#&#8203;3089]: https://github.com/launchbadge/sqlx/pull/3089

[#&#8203;3098]: https://github.com/launchbadge/sqlx/pull/3098

###
[`v0.7.3`](https://github.com/launchbadge/sqlx/blob/HEAD/CHANGELOG.md#073---2023-11-22)

38 pull requests were merged this release cycle.

##### Added

- \[[#&#8203;2478]]: feat(citext): support postgres citext
\[\[[@&#8203;hgranthorner](https://github.com/hgranthorner)]]
- \[[#&#8203;2545]]: Add `fixtures_path` in sqlx::test args
\[\[[@&#8203;ripa1995](https://github.com/ripa1995)]]
- \[[#&#8203;2665]]: feat(mysql): support packet splitting
\[\[[@&#8203;tk2217](https://github.com/tk2217)]]
- \[[#&#8203;2752]]: Enhancement
[#&#8203;2747](https://github.com/launchbadge/sqlx/issues/2747)
Provide `fn PgConnectOptions::get_host(&self)`
\[\[[@&#8203;boris-lok](https://github.com/boris-lok)]]
- \[[#&#8203;2769]]: Customize the macro error message based on the
metadata \[\[[@&#8203;Nemo157](https://github.com/Nemo157)]]
- \[[#&#8203;2793]]: derived Hash trait for PgInterval
\[\[[@&#8203;yasamoka](https://github.com/yasamoka)]]
- \[[#&#8203;2801]]: derive FromRow: sqlx(default) for all fields
\[\[[@&#8203;grgi](https://github.com/grgi)]]
- \[[#&#8203;2827]]: Add impl `FromRow` for the unit type
\[\[[@&#8203;nanoqsh](https://github.com/nanoqsh)]]
- \[[#&#8203;2871]]: Add `MySqlConnectOptions::get_database()`
\[\[[@&#8203;shiftrightonce](https://github.com/shiftrightonce)]]
- \[[#&#8203;2873]]: Sqlx Cli: Added force flag to drop database for
postgres \[\[[@&#8203;Vrajs16](https://github.com/Vrajs16)]]
- \[[#&#8203;2894]]: feat: `Text` adapter
\[\[[@&#8203;abonander](https://github.com/abonander)]]

##### Changed

- \[[#&#8203;2701]]: Remove documentation on offline feature
\[\[[@&#8203;Baptistemontan](https://github.com/Baptistemontan)]]
- \[[#&#8203;2713]]: Add additional info regarding using Transaction and
PoolConnection as…
\[\[[@&#8203;satwanjyu](https://github.com/satwanjyu)]]
- \[[#&#8203;2770]]: Update README.md
\[\[[@&#8203;snspinn](https://github.com/snspinn)]]
- \[[#&#8203;2797]]: doc(mysql): document behavior regarding `BOOLEAN`
and the query macros
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;2803]]: Don't use separate temp dir for query jsons (2)
\[\[[@&#8203;mattfbacon](https://github.com/mattfbacon)]]
- \[[#&#8203;2819]]: postgres begin cancel safe
\[\[[@&#8203;conradludgate](https://github.com/conradludgate)]]
- \[[#&#8203;2832]]: Update extra_float_digits default to 2 instead of 3
\[\[[@&#8203;brianheineman](https://github.com/brianheineman)]]
- \[[#&#8203;2865]]: Update Faq - Bulk upsert with optional fields
\[\[[@&#8203;Vrajs16](https://github.com/Vrajs16)]]
- \[[#&#8203;2880]]: feat: use specific message for slow query logs
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;2882]]: Do not require db url for prepare
\[\[[@&#8203;tamasfe](https://github.com/tamasfe)]]
- \[[#&#8203;2890]]: doc(sqlite): cover lack of `NUMERIC` support
\[\[[@&#8203;abonander](https://github.com/abonander)]]
-   \[No PR]: Upgraded `libsqlite3-sys` to 0.27.0
    -   Note: linkage to `libsqlite3-sys` is considered semver-exempt;
        see the release notes for 0.7.0 below for details.

##### Fixed

- \[[#&#8203;2640]]: fix: sqlx::macro db cleanup race condition by
adding a margin to current timestamp
\[\[[@&#8203;fhsgoncalves](https://github.com/fhsgoncalves)]]
- \[[#&#8203;2655]]: \[fix] Urlencode when passing filenames to sqlite3
\[\[[@&#8203;uttarayan21](https://github.com/uttarayan21)]]
- \[[#&#8203;2684]]: Make PgListener recover from UnexpectedEof
\[\[[@&#8203;hamiltop](https://github.com/hamiltop)]]
- \[[#&#8203;2688]]: fix: Make rust_decimal and bigdecimal decoding more
lenient \[\[[@&#8203;cameronbraid](https://github.com/cameronbraid)]]
- \[[#&#8203;2754]]: Is tests/x.py maintained? And I tried fix it.
\[\[[@&#8203;qwerty2501](https://github.com/qwerty2501)]]
- \[[#&#8203;2784]]: fix: decode postgres time without subsecond
\[\[[@&#8203;granddaifuku](https://github.com/granddaifuku)]]
- \[[#&#8203;2806]]: Depend on version of async-std with non-private
spawn-blocking \[\[[@&#8203;A248](https://github.com/A248)]]
- \[[#&#8203;2820]]: fix: correct decoding of `rust_decimal::Decimal`
for high-precision values
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;2822]]: issue
[#&#8203;2821](https://github.com/launchbadge/sqlx/issues/2821) Update
error handling logic when opening a TCP connection
\[\[[@&#8203;anupj](https://github.com/anupj)]]
- \[[#&#8203;2826]]: chore: bump some sqlx-core dependencies
\[\[[@&#8203;djc](https://github.com/djc)]]
- \[[#&#8203;2838]]: Fixes rust_decimal scale for Postgres
\[\[[@&#8203;jkleinknox](https://github.com/jkleinknox)]]
- \[[#&#8203;2847]]: Fix comment in `sqlx migrate add` help text
\[\[[@&#8203;cryeprecision](https://github.com/cryeprecision)]]
- \[[#&#8203;2850]]: fix(core): avoid unncessary wakeups in
`try_stream!()`
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;2856]]: Prevent warnings running `cargo build`
\[\[[@&#8203;nyurik](https://github.com/nyurik)]]
- \[[#&#8203;2864]]: fix(sqlite): use `AtomicUsize` for thread IDs
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;2892]]: Fixed force dropping bug
\[\[[@&#8203;Vrajs16](https://github.com/Vrajs16)]]

[#&#8203;2478]: https://github.com/launchbadge/sqlx/pull/2478

[#&#8203;2545]: https://github.com/launchbadge/sqlx/pull/2545

[#&#8203;2640]: https://github.com/launchbadge/sqlx/pull/2640

[#&#8203;2655]: https://github.com/launchbadge/sqlx/pull/2655

[#&#8203;2665]: https://github.com/launchbadge/sqlx/pull/2665

[#&#8203;2684]: https://github.com/launchbadge/sqlx/pull/2684

[#&#8203;2688]: https://github.com/launchbadge/sqlx/pull/2688

[#&#8203;2701]: https://github.com/launchbadge/sqlx/pull/2701

[#&#8203;2713]: https://github.com/launchbadge/sqlx/pull/2713

[#&#8203;2752]: https://github.com/launchbadge/sqlx/pull/2752

[#&#8203;2754]: https://github.com/launchbadge/sqlx/pull/2754

[#&#8203;2769]: https://github.com/launchbadge/sqlx/pull/2769

[#&#8203;2770]: https://github.com/launchbadge/sqlx/pull/2770

[#&#8203;2782]: https://github.com/launchbadge/sqlx/pull/2782

[#&#8203;2784]: https://github.com/launchbadge/sqlx/pull/2784

[#&#8203;2793]: https://github.com/launchbadge/sqlx/pull/2793

[#&#8203;2797]: https://github.com/launchbadge/sqlx/pull/2797

[#&#8203;2801]: https://github.com/launchbadge/sqlx/pull/2801

[#&#8203;2803]: https://github.com/launchbadge/sqlx/pull/2803

[#&#8203;2806]: https://github.com/launchbadge/sqlx/pull/2806

[#&#8203;2819]: https://github.com/launchbadge/sqlx/pull/2819

[#&#8203;2820]: https://github.com/launchbadge/sqlx/pull/2820

[#&#8203;2822]: https://github.com/launchbadge/sqlx/pull/2822

[#&#8203;2826]: https://github.com/launchbadge/sqlx/pull/2826

[#&#8203;2827]: https://github.com/launchbadge/sqlx/pull/2827

[#&#8203;2832]: https://github.com/launchbadge/sqlx/pull/2832

[#&#8203;2838]: https://github.com/launchbadge/sqlx/pull/2838

[#&#8203;2847]: https://github.com/launchbadge/sqlx/pull/2847

[#&#8203;2850]: https://github.com/launchbadge/sqlx/pull/2850

[#&#8203;2856]: https://github.com/launchbadge/sqlx/pull/2856

[#&#8203;2864]: https://github.com/launchbadge/sqlx/pull/2864

[#&#8203;2865]: https://github.com/launchbadge/sqlx/pull/2865

[#&#8203;2871]: https://github.com/launchbadge/sqlx/pull/2871

[#&#8203;2873]: https://github.com/launchbadge/sqlx/pull/2873

[#&#8203;2880]: https://github.com/launchbadge/sqlx/pull/2880

[#&#8203;2882]: https://github.com/launchbadge/sqlx/pull/2882

[#&#8203;2890]: https://github.com/launchbadge/sqlx/pull/2890

[#&#8203;2892]: https://github.com/launchbadge/sqlx/pull/2892

[#&#8203;2894]: https://github.com/launchbadge/sqlx/pull/2894

</details>

---

### Configuration

📅 **Schedule**: Branch creation - At any time (no schedule defined),
Automerge - At any time (no schedule defined).

🚦 **Automerge**: Enabled.

♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the
rebase/retry checkbox.

🔕 **Ignore**: Close this PR and you won't be reminded about this update
again.

---

- [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check
this box

---

This PR has been generated by [Mend
Renovate](https://www.mend.io/free-developer-tools/renovate/). View
repository job log
[here](https://developer.mend.io/github/SebastianGoeb/kindle-to-anki).

<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzNy4zMzEuMCIsInVwZGF0ZWRJblZlciI6IjM3LjMzMS4wIiwidGFyZ2V0QnJhbmNoIjoibWFpbiIsImxhYmVscyI6W119-->

Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
mikayla-maki referenced this issue in zed-industries/zed Aug 29, 2024
This PR contains the following updates:

| Package | Type | Update | Change |
|---|---|---|---|
| [sqlx](https://github.com/launchbadge/sqlx) | dev-dependencies |
minor | `0.7` -> `0.8` |
| [sqlx](https://github.com/launchbadge/sqlx) | dependencies | minor |
`0.7` -> `0.8` |

### GitHub Vulnerability Alerts

####
[GHSA-xmrp-424f-vfpx](https://github.com/launchbadge/sqlx/issues/3440)

The following presentation at this year's DEF CON was brought to our
attention on the SQLx Discord:

> SQL Injection isn't Dead: Smuggling Queries at the Protocol Level  
>
<http://web.archive.org/web/20240812130923/https://media.defcon.org/DEF%20CON%2032/DEF%20CON%2032%20presentations/DEF%20CON%2032%20-%20Paul%20Gerste%20-%20SQL%20Injection%20Isn't%20Dead%20Smuggling%20Queries%20at%20the%20Protocol%20Level.pdf>
> (Archive link for posterity.)

Essentially, encoding a value larger than 4GiB can cause the length
prefix in the protocol to overflow,
causing the server to interpret the rest of the string as binary
protocol commands or other data.

It appears SQLx _does_ perform truncating casts in a way that could be
problematic,
for example:
<https://github.com/launchbadge/sqlx/blob/6f2905695b9606b5f51b40ce10af63ac9e696bb8/sqlx-postgres/src/arguments.rs#L163>

This code has existed essentially since the beginning, 
so it is reasonable to assume that all published versions `<= 0.8.0` are
affected.

## Mitigation

As always, you should make sure your application is validating
untrustworthy user input.
Reject any input over 4 GiB, or any input that could _encode_ to a
string longer than 4 GiB.
Dynamically built queries are also potentially problematic if it pushes
the message size over this 4 GiB bound.


[`Encode::size_hint()`](https://docs.rs/sqlx/latest/sqlx/trait.Encode.html#method.size_hint)
can be used for sanity checks, but do not assume that the size returned
is accurate.
For example, the `Json<T>` and `Text<T>` adapters have no reasonable way
to predict or estimate the final encoded size,
so they just return `size_of::<T>()` instead.

For web application backends, consider adding some middleware that
limits the size of request bodies by default.

## Resolution

Work has started on a branch to add `#[deny]` directives for the
following Clippy lints:

*
[`cast_possible_truncation`](https://rust-lang.github.io/rust-clippy/master/#/cast_possible_truncation)
*
[`cast_possible_wrap`](https://rust-lang.github.io/rust-clippy/master/#/cast_possible_wrap)
*
[`cast_sign_loss`](https://rust-lang.github.io/rust-clippy/master/#/cast_sign_loss)

and to manually audit the code that they flag.

A fix is expected to be included in the `0.8.1` release (still WIP as of
writing).

---

### Release Notes

<details>
<summary>launchbadge/sqlx (sqlx)</summary>

###
[`v0.8.1`](https://github.com/launchbadge/sqlx/blob/HEAD/CHANGELOG.md#081---2024-08-23)

[Compare
Source](https://github.com/launchbadge/sqlx/compare/v0.8.0...v0.8.1)

16 pull requests were merged this release cycle.

This release contains a fix for [RUSTSEC-2024-0363].

Postgres users are advised to upgrade ASAP as a possible exploit has
been demonstrated:
[#&#8203;3440
(comment)](https://github.com/launchbadge/sqlx/issues/3440#issuecomment-2307956901)

MySQL and SQLite do not *appear* to be exploitable, but upgrading is
recommended nonetheless.

##### Added

- \[[#&#8203;3421]]: correct spelling of
`MySqlConnectOptions::no_engine_substitution()`
\[\[[@&#8203;kolinfluence](https://github.com/kolinfluence)]]
- Deprecates `MySqlConnectOptions::no_engine_subsitution()` (oops) in
favor of the correctly spelled version.

##### Changed

- \[[#&#8203;3376]]: doc: hide `spec_error` module
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- This is a helper module for the macros and was not meant to be
exposed.
- It is not expected to receive any breaking changes for the 0.8.x
release, but is not designed as a public API.
        Use at your own risk.
- \[[#&#8203;3382]]: feat: bumped to `libsqlite3-sys=0.30.1` to support
sqlite 3.46
\[\[[@&#8203;CommanderStorm](https://github.com/CommanderStorm)]]
- \[[#&#8203;3385]]: chore(examples):Migrated the pg-chat example to
ratatui
\[\[[@&#8203;CommanderStorm](https://github.com/CommanderStorm)]]
- \[[#&#8203;3399]]: Upgrade to rustls 0.23
\[\[[@&#8203;djc](https://github.com/djc)]]
- RusTLS now has pluggable cryptography providers: `ring` (the existing
implementation),
        and `aws-lc-rs` which has optional FIPS certification.
- The existing features activating RusTLS (`runtime-tokio-rustls`,
`runtime-async-std-rustls`, `tls-rustls`)
enable the `ring` provider of RusTLS to match the existing behavior so
this *should not* be a breaking change.
- Switch to the `tls-rustls-aws-lc-rs` feature to use the `aws-lc-rs`
provider.
- If using `runtime-tokio-rustls` or `runtime-async-std-rustls`,
this will necessitate switching to the appropriate non-legacy runtime
feature:
            `runtime-tokio` or `runtime-async-std`
- See the RusTLS README for more details:
<https://github.com/rustls/rustls?tab=readme-ov-file#cryptography-providers>

##### Fixed

- \[[#&#8203;2786]]: fix(sqlx-cli): do not clean sqlx during prepare
\[\[[@&#8203;cycraig](https://github.com/cycraig)]]
- \[[#&#8203;3354]]: sqlite: fix inconsistent read-after-write
\[\[[@&#8203;ckampfe](https://github.com/ckampfe)]]
- \[[#&#8203;3371]]: Fix encoding and decoding of MySQL enums in
`sqlx::Type` \[\[[@&#8203;alu](https://github.com/alu)]]
- \[[#&#8203;3374]]: fix: usage of `node12` in `SQLx` action
\[\[[@&#8203;hamirmahal](https://github.com/hamirmahal)]]
- \[[#&#8203;3380]]: chore: replace structopt with clap in examples
\[\[[@&#8203;tottoto](https://github.com/tottoto)]]
- \[[#&#8203;3381]]: Fix CI after Rust 1.80, remove dead feature
references \[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;3384]]: chore(tests): fixed deprecation warnings
\[\[[@&#8203;CommanderStorm](https://github.com/CommanderStorm)]]
- \[[#&#8203;3386]]: fix(dependencys):bumped cargo_metadata to `v0.18.1`
to avoid yanked `v0.14.3`
\[\[[@&#8203;CommanderStorm](https://github.com/CommanderStorm)]]
- \[[#&#8203;3389]]: fix(cli): typo in error for required DB URL
\[\[[@&#8203;ods](https://github.com/ods)]]
- \[[#&#8203;3417]]: Update version to 0.8 in README
\[\[[@&#8203;soucosmo](https://github.com/soucosmo)]]
- \[[#&#8203;3441]]: fix: audit protocol handling
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- This addresses [RUSTSEC-2024-0363] and includes regression tests for
MySQL, Postgres and SQLite.

[#&#8203;2786]: https://github.com/launchbadge/sqlx/pull/2786

[#&#8203;3354]: https://github.com/launchbadge/sqlx/pull/3354

[#&#8203;3371]: https://github.com/launchbadge/sqlx/pull/3371

[#&#8203;3374]: https://github.com/launchbadge/sqlx/pull/3374

[#&#8203;3376]: https://github.com/launchbadge/sqlx/pull/3376

[#&#8203;3380]: https://github.com/launchbadge/sqlx/pull/3380

[#&#8203;3381]: https://github.com/launchbadge/sqlx/pull/3381

[#&#8203;3382]: https://github.com/launchbadge/sqlx/pull/3382

[#&#8203;3384]: https://github.com/launchbadge/sqlx/pull/3384

[#&#8203;3385]: https://github.com/launchbadge/sqlx/pull/3385

[#&#8203;3386]: https://github.com/launchbadge/sqlx/pull/3386

[#&#8203;3389]: https://github.com/launchbadge/sqlx/pull/3389

[#&#8203;3399]: https://github.com/launchbadge/sqlx/pull/3399

[#&#8203;3417]: https://github.com/launchbadge/sqlx/pull/3417

[#&#8203;3421]: https://github.com/launchbadge/sqlx/pull/3421

[#&#8203;3441]: https://github.com/launchbadge/sqlx/pull/3441

[RUSTSEC-2024-0363]:
https://rustsec.org/advisories/RUSTSEC-2024-0363.html

###
[`v0.8.0`](https://github.com/launchbadge/sqlx/blob/HEAD/CHANGELOG.md#080---2024-07-22)

[Compare
Source](https://github.com/launchbadge/sqlx/compare/v0.7.4...v0.8.0)

70 pull requests were merged this release cycle.

[#&#8203;2697] was merged the same day as release 0.7.4 and so was
missed by the automatic CHANGELOG generation.

##### Breaking

- \[[#&#8203;2697]]: fix(macros): only enable chrono when time is
disabled
\[\[[@&#8203;saiintbrisson](https://github.com/saiintbrisson)]]
- \[[#&#8203;2973]]: Generic Associated Types in Database, replacing
HasValueRef, HasArguments, HasStatement
\[\[[@&#8203;nitn3lav](https://github.com/nitn3lav)]]
- \[[#&#8203;2482]]: chore: bump syn to 2.0
\[\[[@&#8203;saiintbrisson](https://github.com/saiintbrisson)]]
- Deprecated type ascription syntax in the query macros was removed.
- \[[#&#8203;2736]]: Fix describe on PostgreSQL views with rules
\[\[[@&#8203;tsing](https://github.com/tsing)]]
- Potentially breaking: nullability inference changes for Postgres.
- \[[#&#8203;2869]]: Implement PgHasArrayType for all references
\[\[[@&#8203;tylerhawkes](https://github.com/tylerhawkes)]]
    -   Conflicts with existing manual implementations.
- \[[#&#8203;2940]]: fix: Decode and Encode derives
([#&#8203;1031](https://github.com/launchbadge/sqlx/issues/1031))
\[\[[@&#8203;benluelo](https://github.com/benluelo)]]
    -   Changes lifetime obligations for field types.
- \[[#&#8203;3064]]: Sqlite explain graph
\[\[[@&#8203;tyrelr](https://github.com/tyrelr)]]
    -   Potentially breaking: nullability inference changes for SQLite.
- \[[#&#8203;3123]]: Reorder attrs in sqlx::test macro
\[\[[@&#8203;bobozaur](https://github.com/bobozaur)]]
- Potentially breaking: attributes on `#[sqlx::test]` usages are applied
in the correct order now.
- \[[#&#8203;3126]]: Make Encode return a result
\[\[[@&#8203;FSMaxB](https://github.com/FSMaxB)]]
- \[[#&#8203;3130]]: Add version information for failed cli migration
([#&#8203;3129](https://github.com/launchbadge/sqlx/issues/3129))
\[\[[@&#8203;FlakM](https://github.com/FlakM)]]
    -   Breaking changes to `MigrateError`.
- \[[#&#8203;3181]]: feat: no tx migration
\[\[[@&#8203;cleverjam](https://github.com/cleverjam)]]
- (Postgres only) migrations that should not run in a transaction can be
flagged by adding `-- no-transaction` to the beginning.
    -   Breaking change: added field to `Migration`
- \[[#&#8203;3184]]: \[BREAKING} fix(sqlite): always use `i64` as
intermediate when decoding
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- integer decoding will now loudly error on overflow instead of silently
truncating.
- some usages of the query!() macros might change an i32 to an i64.
- \[[#&#8203;3252]]: fix `#[derive(sqlx::Type)]` in Postgres
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- Manual implementations of PgHasArrayType for enums will conflict with
the generated one. Delete the manual impl or add `#[sqlx(no_pg_array)]`
where conflicts occur.
    -   Type equality for PgTypeInfo is now schema-aware.
- \[[#&#8203;3329]]: fix: correct handling of arrays of custom types in
Postgres \[\[[@&#8203;abonander](https://github.com/abonander)]]
- Potential breaking change: `PgTypeInfo::with_name()` infers types that
start with `_` to be arrays of the un-prefixed type. Wrap type names in
quotes to bypass this behavior.
- \[[#&#8203;3356]]: breaking: fix name collision in `FromRow`, return
`Error::ColumnDecode` for `TryFrom` errors
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- Breaking behavior change: errors with `#[sqlx(try_from = "T")]` now
return `Error::ColumnDecode` instead of `Error::ColumnNotFound`.
- Breaking because `#[sqlx(default)]` on an individual field or the
struct itself would have previously suppressed the error.
This doesn't seem like good behavior as it could result in some
potentially very difficult bugs.
- Instead, create a wrapper implementing `From` and apply the default
explicitly.
- \[[#&#8203;3337]]: allow rename with rename_all (close
[#&#8203;2896](https://github.com/launchbadge/sqlx/issues/2896))
\[\[[@&#8203;DirectorX](https://github.com/DirectorX)]]
- Changes the precedence of `#[sqlx(rename)]` and `#[sqlx(rename_all)]`
to match the expected behavior (`rename` wins).
- \[[#&#8203;3285]]: fix: use correct names for sslmode options
\[\[[@&#8203;lily-mosquitoes](https://github.com/lily-mosquitoes)]]
- Changes the output of `ConnectOptions::to_url_lossy()` to match what
parsing expects.

##### Added

- \[[#&#8203;2917]]: Add Debug impl for PgRow
\[\[[@&#8203;g-bartoszek](https://github.com/g-bartoszek)]]
- \[[#&#8203;3113]]: feat: new derive feature flag
\[\[[@&#8203;saiintbrisson](https://github.com/saiintbrisson)]]
- \[[#&#8203;3154]]: feat: add `MySqlTime`, audit `mysql::types` for
panics \[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;3188]]: feat(cube): support postgres cube
\[\[[@&#8203;jayy-lmao](https://github.com/jayy-lmao)]]
- \[[#&#8203;3244]]: feat: support `NonZero*` scalar types
\[\[[@&#8203;AlphaKeks](https://github.com/AlphaKeks)]]
- \[[#&#8203;3260]]: feat: Add set_update_hook on SqliteConnection
\[\[[@&#8203;gridbox](https://github.com/gridbox)]]
- \[[#&#8203;3291]]: feat: support the Postgres Bool type for the Any
driver \[\[[@&#8203;etorreborre](https://github.com/etorreborre)]]
- \[[#&#8203;3293]]: Add LICENSE-\* files to crates
\[\[[@&#8203;LecrisUT](https://github.com/LecrisUT)]]
- \[[#&#8203;3303]]: add array support for NonZeroI\* in postgres
\[\[[@&#8203;JohannesIBK](https://github.com/JohannesIBK)]]
- \[[#&#8203;3311]]: Add example on how to use Transaction as Executor
\[\[[@&#8203;Lachstec](https://github.com/Lachstec)]]
- \[[#&#8203;3343]]: Add support for PostgreSQL HSTORE data type
\[\[[@&#8203;KobusEllis](https://github.com/KobusEllis)]]

##### Changed

- \[[#&#8203;2652]]: MySQL: Remove collation compatibility check for
strings \[\[[@&#8203;alu](https://github.com/alu)]]
- \[[#&#8203;2960]]: Removed `Send` trait bound from argument binding
\[\[[@&#8203;bobozaur](https://github.com/bobozaur)]]
- \[[#&#8203;2970]]: refactor: lift type mappings into driver crates
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;3148]]: Bump libsqlite3-sys to v0.28
\[\[[@&#8203;NfNitLoop](https://github.com/NfNitLoop)]]
- Note: version bumps to `libsqlite3-sys` are not considered breaking
changes as per our semver guarantees.
- \[[#&#8203;3265]]: perf: box `MySqlConnection` to reduce sizes of
futures
\[\[[@&#8203;stepantubanov](https://github.com/stepantubanov)]]
- \[[#&#8203;3352]]: chore:added a testcase for `sqlx migrate add ...`
\[\[[@&#8203;CommanderStorm](https://github.com/CommanderStorm)]]
- \[[#&#8203;3340]]: ci: Add job to check that sqlx builds with its
declared minimum dependencies
\[\[[@&#8203;iamjpotts](https://github.com/iamjpotts)]]

##### Fixed

- \[[#&#8203;2702]]: Constrain cyclic associated types to themselves
\[\[[@&#8203;BadBastion](https://github.com/BadBastion)]]
- \[[#&#8203;2954]]: Fix several inter doc links
\[\[[@&#8203;ralpha](https://github.com/ralpha)]]
- \[[#&#8203;3073]]: feat(logging): Log slow acquires from connection
pool \[\[[@&#8203;iamjpotts](https://github.com/iamjpotts)]]
- \[[#&#8203;3137]]: SqliteConnectOptions::filename() memory fix
([#&#8203;3136](https://github.com/launchbadge/sqlx/issues/3136))
\[\[[@&#8203;hoxxep](https://github.com/hoxxep)]]
- \[[#&#8203;3138]]: PostgreSQL Bugfix: Ensure connection is usable
after failed COPY inside a transaction
\[\[[@&#8203;feikesteenbergen](https://github.com/feikesteenbergen)]]
- \[[#&#8203;3146]]: fix(sqlite): delete unused `ConnectionHandleRaw`
type \[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;3162]]: Drop urlencoding dependency
\[\[[@&#8203;paolobarbolini](https://github.com/paolobarbolini)]]
- \[[#&#8203;3165]]: Bump deps that do not need code changes
\[\[[@&#8203;GnomedDev](https://github.com/GnomedDev)]]
- \[[#&#8203;3167]]: fix(ci): use `docker compose` instead of
`docker-compose`
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;3172]]: fix: Option decoding in any driver
\[\[[@&#8203;pxp9](https://github.com/pxp9)]]
- \[[#&#8203;3173]]: fix(postgres) : int type conversion while decoding
\[\[[@&#8203;RaghavRox](https://github.com/RaghavRox)]]
- \[[#&#8203;3190]]: Update time to 0.3.36
\[\[[@&#8203;BlackSoulHub](https://github.com/BlackSoulHub)]]
- \[[#&#8203;3191]]: Fix unclean TLS shutdown
\[\[[@&#8203;levkk](https://github.com/levkk)]]
- \[[#&#8203;3194]]: Fix leaking connections in fetch_optional
([#&#8203;2647](https://github.com/launchbadge/sqlx/issues/2647))
\[\[[@&#8203;danjpgriffin](https://github.com/danjpgriffin)]]
- \[[#&#8203;3216]]: security: bump rustls to 0.21.11
\[\[[@&#8203;toxeus](https://github.com/toxeus)]]
- \[[#&#8203;3230]]: fix: sqlite pragma order for auto_vacuum
\[\[[@&#8203;jasonish](https://github.com/jasonish)]]
- \[[#&#8203;3233]]: fix: get_filename should not consume self
\[\[[@&#8203;jasonish](https://github.com/jasonish)]]
- \[[#&#8203;3234]]: fix(ci): pin Rust version, ditch unmaintained
actions \[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;3236]]: fix: resolve `path` ownership problems when using
`sqlx_macros_unstable`
\[\[[@&#8203;lily-mosquitoes](https://github.com/lily-mosquitoes)]]
- \[[#&#8203;3254]]: fix: hide `sqlx_postgres::any`
\[\[[@&#8203;Zarathustra2](https://github.com/Zarathustra2)]]
- \[[#&#8203;3266]]: ci: MariaDB - add back 11.4 and add 11.5
\[\[[@&#8203;grooverdan](https://github.com/grooverdan)]]
- \[[#&#8203;3267]]: ci: syntax fix
\[\[[@&#8203;grooverdan](https://github.com/grooverdan)]]
- \[[#&#8203;3271]]: docs(sqlite): fix typo - unixtime() -> unixepoch()
\[\[[@&#8203;joelkoen](https://github.com/joelkoen)]]
- \[[#&#8203;3276]]: Invert boolean for `migrate` error message.
([#&#8203;3275](https://github.com/launchbadge/sqlx/issues/3275))
\[\[[@&#8203;nk9](https://github.com/nk9)]]
- \[[#&#8203;3279]]: fix Clippy errors
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;3288]]: fix: sqlite update_hook char types
\[\[[@&#8203;jasonish](https://github.com/jasonish)]]
- \[[#&#8203;3297]]: Pass the `persistent` query setting when preparing
queries with the `Any` driver
\[\[[@&#8203;etorreborre](https://github.com/etorreborre)]]
- \[[#&#8203;3298]]: Track null arguments in order to provide the
appropriate type when converting them.
\[\[[@&#8203;etorreborre](https://github.com/etorreborre)]]
- \[[#&#8203;3312]]: doc: Minor rust docs fixes
\[\[[@&#8203;SrGesus](https://github.com/SrGesus)]]
- \[[#&#8203;3327]]: chore: fixed one usage of `select_input_type!()`
being unhygenic
\[\[[@&#8203;CommanderStorm](https://github.com/CommanderStorm)]]
- \[[#&#8203;3328]]: fix(ci): comment not separated from other
characters \[\[[@&#8203;hamirmahal](https://github.com/hamirmahal)]]
- \[[#&#8203;3341]]: refactor: Resolve cargo check warnings in postgres
examples \[\[[@&#8203;iamjpotts](https://github.com/iamjpotts)]]
- \[[#&#8203;3346]]: fix(postgres): don't panic if `M` or `C` Notice
fields are not UTF-8
\[\[[@&#8203;YgorSouza](https://github.com/YgorSouza)]]
- \[[#&#8203;3350]]: fix:the `json`-feature should activate
`sqlx-postgres?/json` as well
\[\[[@&#8203;CommanderStorm](https://github.com/CommanderStorm)]]
- \[[#&#8203;3353]]: fix: build script new line at eof
\[\[[@&#8203;Zarthus](https://github.com/Zarthus)]]
- (no PR): activate `clock` and `std` features of
`workspace.dependencies.chrono`.

[#&#8203;2482]: https://github.com/launchbadge/sqlx/pull/2482

[#&#8203;2652]: https://github.com/launchbadge/sqlx/pull/2652

[#&#8203;2697]: https://github.com/launchbadge/sqlx/pull/2697

[#&#8203;2702]: https://github.com/launchbadge/sqlx/pull/2702

[#&#8203;2736]: https://github.com/launchbadge/sqlx/pull/2736

[#&#8203;2869]: https://github.com/launchbadge/sqlx/pull/2869

[#&#8203;2917]: https://github.com/launchbadge/sqlx/pull/2917

[#&#8203;2940]: https://github.com/launchbadge/sqlx/pull/2940

[#&#8203;2954]: https://github.com/launchbadge/sqlx/pull/2954

[#&#8203;2960]: https://github.com/launchbadge/sqlx/pull/2960

[#&#8203;2970]: https://github.com/launchbadge/sqlx/pull/2970

[#&#8203;2973]: https://github.com/launchbadge/sqlx/pull/2973

[#&#8203;3064]: https://github.com/launchbadge/sqlx/pull/3064

[#&#8203;3073]: https://github.com/launchbadge/sqlx/pull/3073

[#&#8203;3113]: https://github.com/launchbadge/sqlx/pull/3113

[#&#8203;3123]: https://github.com/launchbadge/sqlx/pull/3123

[#&#8203;3126]: https://github.com/launchbadge/sqlx/pull/3126

[#&#8203;3130]: https://github.com/launchbadge/sqlx/pull/3130

[#&#8203;3137]: https://github.com/launchbadge/sqlx/pull/3137

[#&#8203;3138]: https://github.com/launchbadge/sqlx/pull/3138

[#&#8203;3146]: https://github.com/launchbadge/sqlx/pull/3146

[#&#8203;3148]: https://github.com/launchbadge/sqlx/pull/3148

[#&#8203;3154]: https://github.com/launchbadge/sqlx/pull/3154

[#&#8203;3162]: https://github.com/launchbadge/sqlx/pull/3162

[#&#8203;3165]: https://github.com/launchbadge/sqlx/pull/3165

[#&#8203;3167]: https://github.com/launchbadge/sqlx/pull/3167

[#&#8203;3172]: https://github.com/launchbadge/sqlx/pull/3172

[#&#8203;3173]: https://github.com/launchbadge/sqlx/pull/3173

[#&#8203;3181]: https://github.com/launchbadge/sqlx/pull/3181

[#&#8203;3184]: https://github.com/launchbadge/sqlx/pull/3184

[#&#8203;3188]: https://github.com/launchbadge/sqlx/pull/3188

[#&#8203;3190]: https://github.com/launchbadge/sqlx/pull/3190

[#&#8203;3191]: https://github.com/launchbadge/sqlx/pull/3191

[#&#8203;3194]: https://github.com/launchbadge/sqlx/pull/3194

[#&#8203;3216]: https://github.com/launchbadge/sqlx/pull/3216

[#&#8203;3230]: https://github.com/launchbadge/sqlx/pull/3230

[#&#8203;3233]: https://github.com/launchbadge/sqlx/pull/3233

[#&#8203;3234]: https://github.com/launchbadge/sqlx/pull/3234

[#&#8203;3236]: https://github.com/launchbadge/sqlx/pull/3236

[#&#8203;3244]: https://github.com/launchbadge/sqlx/pull/3244

[#&#8203;3252]: https://github.com/launchbadge/sqlx/pull/3252

[#&#8203;3254]: https://github.com/launchbadge/sqlx/pull/3254

[#&#8203;3260]: https://github.com/launchbadge/sqlx/pull/3260

[#&#8203;3265]: https://github.com/launchbadge/sqlx/pull/3265

[#&#8203;3266]: https://github.com/launchbadge/sqlx/pull/3266

[#&#8203;3267]: https://github.com/launchbadge/sqlx/pull/3267

[#&#8203;3271]: https://github.com/launchbadge/sqlx/pull/3271

[#&#8203;3276]: https://github.com/launchbadge/sqlx/pull/3276

[#&#8203;3279]: https://github.com/launchbadge/sqlx/pull/3279

[#&#8203;3285]: https://github.com/launchbadge/sqlx/pull/3285

[#&#8203;3288]: https://github.com/launchbadge/sqlx/pull/3288

[#&#8203;3291]: https://github.com/launchbadge/sqlx/pull/3291

[#&#8203;3293]: https://github.com/launchbadge/sqlx/pull/3293

[#&#8203;3297]: https://github.com/launchbadge/sqlx/pull/3297

[#&#8203;3298]: https://github.com/launchbadge/sqlx/pull/3298

[#&#8203;3303]: https://github.com/launchbadge/sqlx/pull/3303

[#&#8203;3311]: https://github.com/launchbadge/sqlx/pull/3311

[#&#8203;3312]: https://github.com/launchbadge/sqlx/pull/3312

[#&#8203;3327]: https://github.com/launchbadge/sqlx/pull/3327

[#&#8203;3328]: https://github.com/launchbadge/sqlx/pull/3328

[#&#8203;3329]: https://github.com/launchbadge/sqlx/pull/3329

[#&#8203;3337]: https://github.com/launchbadge/sqlx/pull/3337

[#&#8203;3340]: https://github.com/launchbadge/sqlx/pull/3340

[#&#8203;3341]: https://github.com/launchbadge/sqlx/pull/3341

[#&#8203;3343]: https://github.com/launchbadge/sqlx/pull/3343

[#&#8203;3346]: https://github.com/launchbadge/sqlx/pull/3346

[#&#8203;3350]: https://github.com/launchbadge/sqlx/pull/3350

[#&#8203;3352]: https://github.com/launchbadge/sqlx/pull/3352

[#&#8203;3353]: https://github.com/launchbadge/sqlx/pull/3353

[#&#8203;3356]: https://github.com/launchbadge/sqlx/pull/3356

###
[`v0.7.4`](https://github.com/launchbadge/sqlx/blob/HEAD/CHANGELOG.md#074---2024-03-11)

[Compare
Source](https://github.com/launchbadge/sqlx/compare/v0.7.3...v0.7.4)

38 pull requests were merged this release cycle.

This is officially the **last** release of the 0.7.x release cycle.

As of this release, development of 0.8.0 has begun on `main` and only
high-priority bugfixes may be backported.

##### Added

- \[[#&#8203;2891]]: feat: expose getters for connect options fields
\[\[[@&#8203;saiintbrisson](https://github.com/saiintbrisson)]]
- \[[#&#8203;2902]]: feat: add `to_url_lossy` to connect options
\[\[[@&#8203;lily-mosquitoes](https://github.com/lily-mosquitoes)]]
- \[[#&#8203;2927]]: Support `query!` for cargo-free systems
\[\[[@&#8203;kshramt](https://github.com/kshramt)]]
- \[[#&#8203;2997]]: doc(FAQ): add entry explaining prepared statements
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;3001]]: Update README to clarify MariaDB support
\[\[[@&#8203;iangilfillan](https://github.com/iangilfillan)]]
- \[[#&#8203;3004]]: feat(logging): Add numeric elapsed time field
elapsed_secs \[\[[@&#8203;iamjpotts](https://github.com/iamjpotts)]]
- \[[#&#8203;3007]]: feat: add `raw_sql` API
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- This hopefully makes it easier to find how to execute statements which
are not supported by the default
        prepared statement interfaces `query*()` and `query!()`.
- Improved documentation across the board for the `query*()` functions.
- Deprecated: `execute_many()` and `fetch_many()` on interfaces that use
prepared statements.
- Multiple SQL statements in one query string were only supported by
SQLite because its prepared statement
interface is the *only* way to execute SQL. All other database flavors
forbid multiple statements in
one prepared statement string as an extra defense against SQL injection.
- The new `raw_sql` API retains this functionality because it explicitly
does *not* use prepared statements.
Raw or text-mode query interfaces generally allow multiple statements in
one query string, and this is
supported by all current databases. Due to their nature, however, one
cannot use bind parameters with them.
- If this change affects you, an issue is open for discussion:
[https://github.com/launchbadge/sqlx/issues/3108](https://github.com/launchbadge/sqlx/issues/3108)
- \[[#&#8203;3011]]: Added support to IpAddr with MySQL/MariaDB.
\[\[[@&#8203;Icerath](https://github.com/Icerath)]]
- \[[#&#8203;3013]]: Add default implementation for PgInterval
\[\[[@&#8203;pawurb](https://github.com/pawurb)]]
- \[[#&#8203;3018]]: Add default implementation for PgMoney
\[\[[@&#8203;pawurb](https://github.com/pawurb)]]
- \[[#&#8203;3026]]: Update docs to reflect support for MariaDB data
types \[\[[@&#8203;iangilfillan](https://github.com/iangilfillan)]]
- \[[#&#8203;3037]]: feat(mysql): allow to connect with mysql driver
without default behavor
\[\[[@&#8203;darkecho731](https://github.com/darkecho731)]]

##### Changed

- \[[#&#8203;2900]]: Show latest url to docs for macro.migrate
\[\[[@&#8203;Vrajs16](https://github.com/Vrajs16)]]
- \[[#&#8203;2914]]: Use `create_new` instead of `atomic-file-write`
\[\[[@&#8203;mattfbacon](https://github.com/mattfbacon)]]
- \[[#&#8203;2926]]: docs: update example for `PgConnectOptions`
\[\[[@&#8203;Fyko](https://github.com/Fyko)]]
- \[[#&#8203;2989]]: sqlx-core: Remove dotenvy dependency
\[\[[@&#8203;joshtriplett](https://github.com/joshtriplett)]]
- \[[#&#8203;2996]]: chore: Update ahash to 0.8.7
\[\[[@&#8203;takenoko-gohan](https://github.com/takenoko-gohan)]]
- \[[#&#8203;3006]]: chore(deps): Replace unmaintained tempdir crate
with tempfile \[\[[@&#8203;iamjpotts](https://github.com/iamjpotts)]]
- \[[#&#8203;3008]]: chore: Ignore .sqlx folder created by running ci
steps locally \[\[[@&#8203;iamjpotts](https://github.com/iamjpotts)]]
- \[[#&#8203;3009]]: chore(dev-deps): Upgrade env_logger from 0.9 to
0.11 \[\[[@&#8203;iamjpotts](https://github.com/iamjpotts)]]
- \[[#&#8203;3010]]: chore(deps): Upgrade criterion to 0.5.1
\[\[[@&#8203;iamjpotts](https://github.com/iamjpotts)]]
- \[[#&#8203;3050]]: Optimize SASL auth in sqlx-postgres
\[\[[@&#8203;mirek26](https://github.com/mirek26)]]
- \[[#&#8203;3055]]: Set TCP_NODELAY option on TCP sockets
\[\[[@&#8203;mirek26](https://github.com/mirek26)]]
- \[[#&#8203;3065]]: Improve max_lifetime handling
\[\[[@&#8203;mirek26](https://github.com/mirek26)]]
- \[[#&#8203;3072]]: Change the name of "inner" function generated by
`#[sqlx::test]` \[\[[@&#8203;ciffelia](https://github.com/ciffelia)]]
- \[[#&#8203;3083]]: Remove sha1 because it's not being used in postgres
\[\[[@&#8203;rafaelGuerreiro](https://github.com/rafaelGuerreiro)]]

##### Fixed

- \[[#&#8203;2898]]: Fixed docs
\[\[[@&#8203;Vrajs16](https://github.com/Vrajs16)]]
- \[[#&#8203;2905]]: fix(mysql): Close prepared statement if persistence
is disabled
\[\[[@&#8203;larsschumacher](https://github.com/larsschumacher)]]
- \[[#&#8203;2913]]: Fix handling of deferred constraints
\[\[[@&#8203;Thomasdezeeuw](https://github.com/Thomasdezeeuw)]]
- \[[#&#8203;2919]]: fix duplicate "\`" in FromRow "default" attribute
doc comment \[\[[@&#8203;shengsheng](https://github.com/shengsheng)]]
- \[[#&#8203;2932]]: fix(postgres): avoid unnecessary flush in
PgCopyIn::read_from \[\[[@&#8203;tsing](https://github.com/tsing)]]
- \[[#&#8203;2955]]: Minor fixes
\[\[[@&#8203;Dawsoncodes](https://github.com/Dawsoncodes)]]
- \[[#&#8203;2963]]: Fixed ReadMe badge styling
\[\[[@&#8203;tadghh](https://github.com/tadghh)]]
- \[[#&#8203;2976]]: fix: AnyRow not support PgType::Varchar
\[\[[@&#8203;holicc](https://github.com/holicc)]]
- \[[#&#8203;3053]]: fix: do not panic when binding a large BigDecimal
\[\[[@&#8203;Ekleog](https://github.com/Ekleog)]]
- \[[#&#8203;3056]]: fix: spans in sqlite tracing
([#&#8203;2876](https://github.com/launchbadge/sqlx/issues/2876))
\[\[[@&#8203;zoomiti](https://github.com/zoomiti)]]
- \[[#&#8203;3089]]: fix(migrate): improve error message when parsing
version from filename
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;3098]]: Migrations fixes
\[\[[@&#8203;abonander](https://github.com/abonander)]]
    -   Unhides `sqlx::migrate::Migrator`.
- Improves I/O error message when failing to read a file in
`migrate!()`.

[#&#8203;2891]: https://github.com/launchbadge/sqlx/pull/2891

[#&#8203;2898]: https://github.com/launchbadge/sqlx/pull/2898

[#&#8203;2900]: https://github.com/launchbadge/sqlx/pull/2900

[#&#8203;2902]: https://github.com/launchbadge/sqlx/pull/2902

[#&#8203;2905]: https://github.com/launchbadge/sqlx/pull/2905

[#&#8203;2913]: https://github.com/launchbadge/sqlx/pull/2913

[#&#8203;2914]: https://github.com/launchbadge/sqlx/pull/2914

[#&#8203;2919]: https://github.com/launchbadge/sqlx/pull/2919

[#&#8203;2926]: https://github.com/launchbadge/sqlx/pull/2926

[#&#8203;2927]: https://github.com/launchbadge/sqlx/pull/2927

[#&#8203;2932]: https://github.com/launchbadge/sqlx/pull/2932

[#&#8203;2955]: https://github.com/launchbadge/sqlx/pull/2955

[#&#8203;2963]: https://github.com/launchbadge/sqlx/pull/2963

[#&#8203;2976]: https://github.com/launchbadge/sqlx/pull/2976

[#&#8203;2989]: https://github.com/launchbadge/sqlx/pull/2989

[#&#8203;2996]: https://github.com/launchbadge/sqlx/pull/2996

[#&#8203;2997]: https://github.com/launchbadge/sqlx/pull/2997

[#&#8203;3001]: https://github.com/launchbadge/sqlx/pull/3001

[#&#8203;3004]: https://github.com/launchbadge/sqlx/pull/3004

[#&#8203;3006]: https://github.com/launchbadge/sqlx/pull/3006

[#&#8203;3007]: https://github.com/launchbadge/sqlx/pull/3007

[#&#8203;3008]: https://github.com/launchbadge/sqlx/pull/3008

[#&#8203;3009]: https://github.com/launchbadge/sqlx/pull/3009

[#&#8203;3010]: https://github.com/launchbadge/sqlx/pull/3010

[#&#8203;3011]: https://github.com/launchbadge/sqlx/pull/3011

[#&#8203;3013]: https://github.com/launchbadge/sqlx/pull/3013

[#&#8203;3018]: https://github.com/launchbadge/sqlx/pull/3018

[#&#8203;3026]: https://github.com/launchbadge/sqlx/pull/3026

[#&#8203;3037]: https://github.com/launchbadge/sqlx/pull/3037

[#&#8203;3050]: https://github.com/launchbadge/sqlx/pull/3050

[#&#8203;3053]: https://github.com/launchbadge/sqlx/pull/3053

[#&#8203;3055]: https://github.com/launchbadge/sqlx/pull/3055

[#&#8203;3056]: https://github.com/launchbadge/sqlx/pull/3056

[#&#8203;3065]: https://github.com/launchbadge/sqlx/pull/3065

[#&#8203;3072]: https://github.com/launchbadge/sqlx/pull/3072

[#&#8203;3083]: https://github.com/launchbadge/sqlx/pull/3083

[#&#8203;3089]: https://github.com/launchbadge/sqlx/pull/3089

[#&#8203;3098]: https://github.com/launchbadge/sqlx/pull/3098

###
[`v0.7.3`](https://github.com/launchbadge/sqlx/blob/HEAD/CHANGELOG.md#073---2023-11-22)

38 pull requests were merged this release cycle.

##### Added

- \[[#&#8203;2478]]: feat(citext): support postgres citext
\[\[[@&#8203;hgranthorner](https://github.com/hgranthorner)]]
- \[[#&#8203;2545]]: Add `fixtures_path` in sqlx::test args
\[\[[@&#8203;ripa1995](https://github.com/ripa1995)]]
- \[[#&#8203;2665]]: feat(mysql): support packet splitting
\[\[[@&#8203;tk2217](https://github.com/tk2217)]]
- \[[#&#8203;2752]]: Enhancement
[#&#8203;2747](https://github.com/launchbadge/sqlx/issues/2747)
Provide `fn PgConnectOptions::get_host(&self)`
\[\[[@&#8203;boris-lok](https://github.com/boris-lok)]]
- \[[#&#8203;2769]]: Customize the macro error message based on the
metadata \[\[[@&#8203;Nemo157](https://github.com/Nemo157)]]
- \[[#&#8203;2793]]: derived Hash trait for PgInterval
\[\[[@&#8203;yasamoka](https://github.com/yasamoka)]]
- \[[#&#8203;2801]]: derive FromRow: sqlx(default) for all fields
\[\[[@&#8203;grgi](https://github.com/grgi)]]
- \[[#&#8203;2827]]: Add impl `FromRow` for the unit type
\[\[[@&#8203;nanoqsh](https://github.com/nanoqsh)]]
- \[[#&#8203;2871]]: Add `MySqlConnectOptions::get_database()`
\[\[[@&#8203;shiftrightonce](https://github.com/shiftrightonce)]]
- \[[#&#8203;2873]]: Sqlx Cli: Added force flag to drop database for
postgres \[\[[@&#8203;Vrajs16](https://github.com/Vrajs16)]]
- \[[#&#8203;2894]]: feat: `Text` adapter
\[\[[@&#8203;abonander](https://github.com/abonander)]]

##### Changed

- \[[#&#8203;2701]]: Remove documentation on offline feature
\[\[[@&#8203;Baptistemontan](https://github.com/Baptistemontan)]]
- \[[#&#8203;2713]]: Add additional info regarding using Transaction and
PoolConnection as…
\[\[[@&#8203;satwanjyu](https://github.com/satwanjyu)]]
- \[[#&#8203;2770]]: Update README.md
\[\[[@&#8203;snspinn](https://github.com/snspinn)]]
- \[[#&#8203;2797]]: doc(mysql): document behavior regarding `BOOLEAN`
and the query macros
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;2803]]: Don't use separate temp dir for query jsons (2)
\[\[[@&#8203;mattfbacon](https://github.com/mattfbacon)]]
- \[[#&#8203;2819]]: postgres begin cancel safe
\[\[[@&#8203;conradludgate](https://github.com/conradludgate)]]
- \[[#&#8203;2832]]: Update extra_float_digits default to 2 instead of 3
\[\[[@&#8203;brianheineman](https://github.com/brianheineman)]]
- \[[#&#8203;2865]]: Update Faq - Bulk upsert with optional fields
\[\[[@&#8203;Vrajs16](https://github.com/Vrajs16)]]
- \[[#&#8203;2880]]: feat: use specific message for slow query logs
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;2882]]: Do not require db url for prepare
\[\[[@&#8203;tamasfe](https://github.com/tamasfe)]]
- \[[#&#8203;2890]]: doc(sqlite): cover lack of `NUMERIC` support
\[\[[@&#8203;abonander](https://github.com/abonander)]]
-   \[No PR]: Upgraded `libsqlite3-sys` to 0.27.0
    -   Note: linkage to `libsqlite3-sys` is considered semver-exempt;
        see the release notes for 0.7.0 below for details.

##### Fixed

- \[[#&#8203;2640]]: fix: sqlx::macro db cleanup race condition by
adding a margin to current timestamp
\[\[[@&#8203;fhsgoncalves](https://github.com/fhsgoncalves)]]
- \[[#&#8203;2655]]: \[fix] Urlencode when passing filenames to sqlite3
\[\[[@&#8203;uttarayan21](https://github.com/uttarayan21)]]
- \[[#&#8203;2684]]: Make PgListener recover from UnexpectedEof
\[\[[@&#8203;hamiltop](https://github.com/hamiltop)]]
- \[[#&#8203;2688]]: fix: Make rust_decimal and bigdecimal decoding more
lenient \[\[[@&#8203;cameronbraid](https://github.com/cameronbraid)]]
- \[[#&#8203;2754]]: Is tests/x.py maintained? And I tried fix it.
\[\[[@&#8203;qwerty2501](https://github.com/qwerty2501)]]
- \[[#&#8203;2784]]: fix: decode postgres time without subsecond
\[\[[@&#8203;granddaifuku](https://github.com/granddaifuku)]]
- \[[#&#8203;2806]]: Depend on version of async-std with non-private
spawn-blocking \[\[[@&#8203;A248](https://github.com/A248)]]
- \[[#&#8203;2820]]: fix: correct decoding of `rust_decimal::Decimal`
for high-precision values
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;2822]]: issue
[#&#8203;2821](https://github.com/launchbadge/sqlx/issues/2821) Update
error handling logic when opening a TCP connection
\[\[[@&#8203;anupj](https://github.com/anupj)]]
- \[[#&#8203;2826]]: chore: bump some sqlx-core dependencies
\[\[[@&#8203;djc](https://github.com/djc)]]
- \[[#&#8203;2838]]: Fixes rust_decimal scale for Postgres
\[\[[@&#8203;jkleinknox](https://github.com/jkleinknox)]]
- \[[#&#8203;2847]]: Fix comment in `sqlx migrate add` help text
\[\[[@&#8203;cryeprecision](https://github.com/cryeprecision)]]
- \[[#&#8203;2850]]: fix(core): avoid unncessary wakeups in
`try_stream!()`
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;2856]]: Prevent warnings running `cargo build`
\[\[[@&#8203;nyurik](https://github.com/nyurik)]]
- \[[#&#8203;2864]]: fix(sqlite): use `AtomicUsize` for thread IDs
\[\[[@&#8203;abonander](https://github.com/abonander)]]
- \[[#&#8203;2892]]: Fixed force dropping bug
\[\[[@&#8203;Vrajs16](https://github.com/Vrajs16)]]

[#&#8203;2478]: https://github.com/launchbadge/sqlx/pull/2478

[#&#8203;2545]: https://github.com/launchbadge/sqlx/pull/2545

[#&#8203;2640]: https://github.com/launchbadge/sqlx/pull/2640

[#&#8203;2655]: https://github.com/launchbadge/sqlx/pull/2655

[#&#8203;2665]: https://github.com/launchbadge/sqlx/pull/2665

[#&#8203;2684]: https://github.com/launchbadge/sqlx/pull/2684

[#&#8203;2688]: https://github.com/launchbadge/sqlx/pull/2688

[#&#8203;2701]: https://github.com/launchbadge/sqlx/pull/2701

[#&#8203;2713]: https://github.com/launchbadge/sqlx/pull/2713

[#&#8203;2752]: https://github.com/launchbadge/sqlx/pull/2752

[#&#8203;2754]: https://github.com/launchbadge/sqlx/pull/2754

[#&#8203;2769]: https://github.com/launchbadge/sqlx/pull/2769

[#&#8203;2770]: https://github.com/launchbadge/sqlx/pull/2770

[#&#8203;2782]: https://github.com/launchbadge/sqlx/pull/2782

[#&#8203;2784]: https://github.com/launchbadge/sqlx/pull/2784

[#&#8203;2793]: https://github.com/launchbadge/sqlx/pull/2793

[#&#8203;2797]: https://github.com/launchbadge/sqlx/pull/2797

[#&#8203;2801]: https://github.com/launchbadge/sqlx/pull/2801

[#&#8203;2803]: https://github.com/launchbadge/sqlx/pull/2803

[#&#8203;2806]: https://github.com/launchbadge/sqlx/pull/2806

[#&#8203;2819]: https://github.com/launchbadge/sqlx/pull/2819

[#&#8203;2820]: https://github.com/launchbadge/sqlx/pull/2820

[#&#8203;2822]: https://github.com/launchbadge/sqlx/pull/2822

[#&#8203;2826]: https://github.com/launchbadge/sqlx/pull/2826

[#&#8203;2827]: https://github.com/launchbadge/sqlx/pull/2827

[#&#8203;2832]: https://github.com/launchbadge/sqlx/pull/2832

[#&#8203;2838]: https://github.com/launchbadge/sqlx/pull/2838

[#&#8203;2847]: https://github.com/launchbadge/sqlx/pull/2847

[#&#8203;2850]: https://github.com/launchbadge/sqlx/pull/2850

[#&#8203;2856]: https://github.com/launchbadge/sqlx/pull/2856

[#&#8203;2864]: https://github.com/launchbadge/sqlx/pull/2864

[#&#8203;2865]: https://github.com/launchbadge/sqlx/pull/2865

[#&#8203;2871]: https://github.com/launchbadge/sqlx/pull/2871

[#&#8203;2873]: https://github.com/launchbadge/sqlx/pull/2873

[#&#8203;2880]: https://github.com/launchbadge/sqlx/pull/2880

[#&#8203;2882]: https://github.com/launchbadge/sqlx/pull/2882

[#&#8203;2890]: https://github.com/launchbadge/sqlx/pull/2890

[#&#8203;2892]: https://github.com/launchbadge/sqlx/pull/2892

[#&#8203;2894]: https://github.com/launchbadge/sqlx/pull/2894

</details>

---

### Configuration

📅 **Schedule**: Branch creation - "" in timezone America/New_York,
Automerge - At any time (no schedule defined).

🚦 **Automerge**: Disabled by config. Please merge this manually once you
are satisfied.

♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the
rebase/retry checkbox.

🔕 **Ignore**: Close this PR and you won't be reminded about these
updates again.

---

- [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check
this box

---

Release Notes:

- N/A

<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzOC4yNi4xIiwidXBkYXRlZEluVmVyIjoiMzguNTYuMCIsInRhcmdldEJyYW5jaCI6Im1haW4iLCJsYWJlbHMiOltdfQ==-->

---------

Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
Co-authored-by: Mikayla <mikayla@zed.dev>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
db:sqlite Related to SQLite enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

4 participants