postgresql-simple-named: Implementation of named parameters for `postgresql-simple` library

[ database, library, mpl, postgresql ] [ Propose Tags ] [ Report a vulnerability ]

Implementation of named parameters for postgresql-simple library.

Here is an exaple of how it could be used in your code:

queryNamed dbConnection [sql|
    SELECT *
    FROM table
    WHERE foo = ?foo
      AND bar = ?bar
      AND baz = ?foo
|] [ "foo" =? "fooBar"
   , "bar" =? "barVar"
   ]

[Skip to Readme]

Downloads

Maintainer's Corner

Package maintainers

For package maintainers and hackage trustees

Candidates

Versions [RSS] 0.0.0.0, 0.0.1.0, 0.0.2.0, 0.0.3.0, 0.0.4.0, 0.0.5.0
Change log CHANGELOG.md
Dependencies base (>=4.11 && <4.20), bytestring (>=0.10 && <0.13), mtl (>=2.2 && <2.4), postgresql-simple (>=0.5 && <0.8), text (>=1.2 && <2.2) [details]
Tested with ghc ==9.0.2, ghc ==9.2.8, ghc ==9.4.8, ghc ==9.6.3, ghc ==9.8.1
License MPL-2.0
Copyright 2019 Holmusk
Author Veronika Romashkina, Dmitrii Kovanikov
Maintainer Holmusk <tech@holmusk.com>
Category Database, PostgreSQL
Home page https://github.com/Holmusk/postgresql-simple-named
Bug tracker https://github.com/Holmusk/postgresql-simple-named/issues
Source repo head: git clone https://github.com/Holmusk/postgresql-simple-named.git
Uploaded by HolmuskTechTeam at 2024-01-04T07:13:31Z
Distributions
Downloads 1711 total (37 in the last 30 days)
Rating (no votes yet) [estimated by Bayesian average]
Your Rating
  • λ
  • λ
  • λ
Status Docs available [build log]
Last success reported on 2024-01-04 [all 1 reports]

Readme for postgresql-simple-named-0.0.5.0

[back to package description]

postgresql-simple-named

Logo

Build status Hackage Stackage Lts Stackage Nightly MPL-2.0 license

This library introduces the implementation of named parameters for the postgresql-simple library. postgresql-simple-named is designed to be used along with the postgresql-simple library, so you could refer there for the original documentation of primary functions. This package solves exclusively one particular problem — gives the ability to use named parameters instead of ? in quasi-quoter queries and offers essential functions for substituting variables in queries (queryNamed, executeNamed).

Example

Operator =? binds named parameters with the corresponding values. Named parameters inside SQL query start with the '?' character and can contain lowercase and uppercase letters, digits and underscore. Below you can find a basic example of how query with named parameters could look like:

queryNamed dbConnection [sql|
    SELECT
        id, name, city
    FROM users
    WHERE name = ?nameParam
      AND age  = ?ageParam

|] [ "nameParam" =? "John"
   , "ageParam"  =? 42
   ]

This feature can be extremely helpful when the query uses some parameters more than once:

query dbConnection [sql|
    SELECT
        col1, col2
    FROM my_table
    WHERE id = ?
      AND (? IS NULL OR id > ? )
      AND (? IS NULL OR id < ? )

|] (someId, minId, minId, maxId, maxId)

This is how the query looks like with the postgresql-simple library. You can rewrite it the following way using the postgresql-simple-named library:

queryNamed dbConnection [sql|
    SELECT
        col1, col2
    FROM my_table
    WHERE id = ?someId
      AND (?minId IS NULL OR id > ?minId )
      AND (?maxId IS NULL OR id < ?maxId )

|] [ "someId" =? 42
   , "minId"  =? 1
   , "maxId"  =? 100
   ]

How to build

Build the library with either cabal new-build or stack build.

How to test locally

  • Run DB in a Docker in a separate terminal window using command:
    docker run -p 5432:5432 -e POSTGRES_PASSWORD=postgres postgres:15
    
  • Run tests using cabal new-test or stack test