YeshQL
YesQL-style SQL database abstraction.
YeshQL implements quasiquoters that allow the programmer to write SQL queries
in SQL, and embed these into Haskell programs using quasi-quotation. YeshQL
takes care of generating suitable functions that will run the SQL queries
against a HDBC database driver, and marshal values between Haskell and SQL.
In order to do this properly, YeshQL extends SQL syntax with type annotations
and function names; other than that, it is perfectly ignorant about the SQL
syntax itself. See the YesQL
Readme for the
full rationale - Haskell and Clojure are sufficiently different languages, but
the reasoning behind YesQL applies to YeshQL almost unchanged.
Installation
Use stack or cabal to
install. Nothing extraordinary here.
Usage
In short:
{-#LANGUAGE QuasiQuotes #-}
import MyProject.DatabaseConnection (withDB)
import Database.HDBC
import Database.YeshQL
[yesh|
-- name:getUser :: (String)
-- :userID :: Int
SELECT username FROM users WHERE id = :userID
|]
main = withDB $ \conn -> do
username <- getUser 1 conn
putStrLn username
Please refer to the Haddock documentation for further usage details.
Bugs
Probably. The project is hosted at https://github.com/tdammers/yeshql, feel
free to comment there or send a message to [email protected] if you find any.
Something about the name
YeshQL is rather heavily inspired by YesQL, so it makes sense to blatantly
steal most of the name. Throwing in an “H” for good measure (this being Haskell
and all) makes it sound like Sean Connery, which automatically increases
aweshomenesh, so that’sh what we’ll roll with.
License / Copying
YeshQL is Free Software and provided as-is. Please see the enclosed LICENSE
file for details.
Legacy / Backwards-Compatibility Notice
Note that the yeshql
package, starting with the 4.1 release, is now
merely a wrapper around yeshql-core
and yeshql-hdbc
, re-exporting what is
hopefully close enough to the original yeshql
API to be somewhat compatible.
This is because starting with this release, yeshql
has been split up into a
frontend, which takes care of query parsing and the whole TemplateHaskell
machinery, and several backends - at the time of writing, these are
yeshql-hdbc
, which uses HDBC just like the original yeshql
package, and
yeshql-postgresql-simpel
, which uses postgresql-simple
. With this
architecture, it is possible to add more backends without affecting the
frontend or any of the other backends.