SQL Params

6.2.0 · active · verified Thu Apr 09

sqlparams is a utility package for converting between various SQL parameter styles. This can simplify the use of SQL parameters in queries by allowing the use of named parameters where only ordinal are supported. Current version is 6.2.0, released on 2024-01-25. It appears to have a regular release cadence, with several minor and major versions released annually.

Warnings

Install

Imports

Quickstart

Demonstrates initializing SQLParams to convert from named to qmark style, then using the `format` method for single and tuple parameters, and `formatmany` for multiple sets of parameters.

import sqlparams

# Convert from named style (e.g., ':name') to qmark style (e.g., '?')
query_converter = sqlparams.SQLParams('named', 'qmark')

# Example 1: Single parameter
sql_in = "SELECT * FROM users WHERE name = :name;"
params_in = {'name': "Thorin"}
sql_out, params_out = query_converter.format(sql_in, params_in)

print(f"Original SQL: {sql_in}")
print(f"Original Params: {params_in}")
print(f"Converted SQL: {sql_out}")
print(f"Converted Params: {params_out}\n")
# Expected: SELECT * FROM users WHERE name = ?; ['Thorin']

# Example 2: Tuple expansion for IN operator
sql_in_in = "SELECT * FROM users WHERE name IN :names;"
params_in_in = {'names': ("Dori", "Nori", "Ori")}
sql_out_in, params_out_in = query_converter.format(sql_in_in, params_in_in)

print(f"Original SQL (IN): {sql_in_in}")
print(f"Original Params (IN): {params_in_in}")
print(f"Converted SQL (IN): {sql_out_in}")
print(f"Converted Params (IN): {params_out_in}\n")
# Expected: SELECT * FROM users WHERE name in (?,?,?); ['Dori', 'Nori', 'Ori']

# Example 3: Multiple parameter sets for executemany
sql_many_in = "UPDATE users SET age = :age WHERE name = :name;"
params_many_in = [
    {'name': "Dwalin", 'age': 169},
    {'name': "Balin", 'age': 178}
]
sql_many_out, params_many_out = query_converter.formatmany(sql_many_in, params_many_in)

print(f"Original SQL (many): {sql_many_in}")
print(f"Original Params (many): {params_many_in}")
print(f"Converted SQL (many): {sql_many_out}")
print(f"Converted Params (many): {params_many_out}")
# Expected: UPDATE users SET age = ? WHERE name = ?; [[169, 'Dwalin'], [178, 'Balin']]

view raw JSON →