Trait duckdb::AppenderParams

source ·
pub trait AppenderParams: Sealed { }
Expand description

Trait used for sets of parameter passed into SQL statements/queries.

Note: Currently, this trait can only be implemented inside this crate. Additionally, it’s methods (which are doc(hidden)) should currently not be considered part of the stable API, although it’s possible they will stabilize in the future.

§Passing parameters to SQLite

Many functions in this library let you pass parameters to SQLite. Doing this lets you avoid any risk of SQL injection, and is simpler than escaping things manually. Aside from deprecated functions and a few helpers, this is indicated by the function taking a generic argument that implements Params (this trait).

§Positional parameters

For cases where you want to pass a list of parameters where the number of parameters is known at compile time, this can be done in one of the following ways:

  • Using the duckdb::params! macro, e.g. thing.query(duckdb::params![1, "foo", bar]). This is mostly useful for heterogeneous lists of parameters, or lists where the number of parameters exceeds 32.

  • For small heterogeneous lists of parameters, they can either be passed as:

    • an array, as in thing.query([1i32, 2, 3, 4]) or thing.query(["foo", "bar", "baz"]).

    • a reference to an array of references, as in thing.query(&["foo", "bar", "baz"]) or thing.query(&[&1i32, &2, &3]).

      (Note: in this case we don’t implement this for slices for coherence reasons, so it really is only for the “reference to array” types — hence why the number of parameters must be <= 32 or you need to reach for duckdb::params!)

    Unfortunately, in the current design it’s not possible to allow this for references to arrays of non-references (e.g. &[1i32, 2, 3]). Code like this should instead either use params!, an array literal, a &[&dyn ToSql] or if none of those work, [ParamsFromIter].

  • As a slice of ToSql trait object references, e.g. &[&dyn ToSql]. This is mostly useful for passing parameter lists around as arguments without having every function take a generic P: Params.

§Example (positional)

fn update_rows(conn: &Connection) -> Result<()> {
    let mut stmt = conn.prepare("INSERT INTO test (a, b) VALUES (?, ?)")?;

    // Using `duckdb::params!`:
    stmt.execute(params![1i32, "blah"])?;

    // array literal — non-references
    stmt.execute([2i32, 3i32])?;

    // array literal — references
    stmt.execute(["foo", "bar"])?;

    // Slice literal, references:
    stmt.execute(&[&2i32, &3i32])?;

    // Note: The types behind the references don't have to be `Sized`
    stmt.execute(&["foo", "bar"])?;

    // However, this doesn't work (see above):
    // stmt.execute(&[1i32, 2i32])?;
    Ok(())
}

§No parameters

You can just use an empty array literal for no params. The duckdb::NO_PARAMS constant which was so common in previous versions of this library is no longer needed (and is now deprecated).

§Example (no parameters)

fn delete_all_users(conn: &Connection) -> Result<()> {
    // Just use an empty array (e.g. `[]`) for no params.
    conn.execute("DELETE FROM users", [])?;
    Ok(())
}

§Dynamic parameter list

If you have a number of parameters which is unknown at compile time (for example, building a dynamic query at runtime), you have two choices:

  • Use a &[&dyn ToSql], which is nice if you have one otherwise might be annoying.
  • Use the [ParamsFromIter] type. This essentially lets you wrap an iterator some T: ToSql with something that implements Params.

A lot of the considerations here are similar either way, so you should see the [ParamsFromIter] documentation for more info / examples.

Implementations on Foreign Types§

source§

impl AppenderParams for &[&dyn ToSql]

source§

impl AppenderParams for [&dyn ToSql; 0]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 1]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 2]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 3]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 4]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 5]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 6]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 7]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 8]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 9]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 10]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 11]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 12]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 13]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 14]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 15]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 16]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 17]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 18]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 19]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 20]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 21]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 22]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 23]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 24]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 25]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 26]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 27]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 29]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 30]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 31]

source§

impl<T: ToSql + ?Sized> AppenderParams for &[&T; 32]

source§

impl<T: ToSql> AppenderParams for [T; 1]

source§

impl<T: ToSql> AppenderParams for [T; 2]

source§

impl<T: ToSql> AppenderParams for [T; 3]

source§

impl<T: ToSql> AppenderParams for [T; 4]

source§

impl<T: ToSql> AppenderParams for [T; 5]

source§

impl<T: ToSql> AppenderParams for [T; 6]

source§

impl<T: ToSql> AppenderParams for [T; 7]

source§

impl<T: ToSql> AppenderParams for [T; 8]

source§

impl<T: ToSql> AppenderParams for [T; 9]

source§

impl<T: ToSql> AppenderParams for [T; 10]

source§

impl<T: ToSql> AppenderParams for [T; 11]

source§

impl<T: ToSql> AppenderParams for [T; 12]

source§

impl<T: ToSql> AppenderParams for [T; 13]

source§

impl<T: ToSql> AppenderParams for [T; 14]

source§

impl<T: ToSql> AppenderParams for [T; 15]

source§

impl<T: ToSql> AppenderParams for [T; 16]

source§

impl<T: ToSql> AppenderParams for [T; 17]

source§

impl<T: ToSql> AppenderParams for [T; 18]

source§

impl<T: ToSql> AppenderParams for [T; 19]

source§

impl<T: ToSql> AppenderParams for [T; 20]

source§

impl<T: ToSql> AppenderParams for [T; 21]

source§

impl<T: ToSql> AppenderParams for [T; 22]

source§

impl<T: ToSql> AppenderParams for [T; 23]

source§

impl<T: ToSql> AppenderParams for [T; 24]

source§

impl<T: ToSql> AppenderParams for [T; 25]

source§

impl<T: ToSql> AppenderParams for [T; 26]

source§

impl<T: ToSql> AppenderParams for [T; 27]

source§

impl<T: ToSql> AppenderParams for [T; 29]

source§

impl<T: ToSql> AppenderParams for [T; 30]

source§

impl<T: ToSql> AppenderParams for [T; 31]

source§

impl<T: ToSql> AppenderParams for [T; 32]

Implementors§