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

Building requests using pre-built strings #18

Open
Gbury opened this issue Jun 2, 2016 · 2 comments
Open

Building requests using pre-built strings #18

Gbury opened this issue Jun 2, 2016 · 2 comments

Comments

@Gbury
Copy link

Gbury commented Jun 2, 2016

It seems that inserting conditions via a preformatted string in a statement does not work. More precisely, consider the follwing piece of code:

module Sqlexpr = Sqlexpr_sqlite.Make(Sqlexpr_concurrency.Id)

let () =
  let db = Sqlexpr.open_db ":memory:" in
  Sqlexpr.execute db [%sqlc "CREATE TABLE foo (name TEXT, price INT)"];
  Sqlexpr.execute db [%sqlc "INSERT INTO foo VALUES (%s,%d)"] "table" 5;

  begin match Sqlexpr.select db [%sqlc "SELECT @d{price} FROM foo WHERE name=%s"] "table" with
  | [ p ] -> Printf.printf "ok\n"
  | _ -> Printf.printf "KO !\n"
  end;

  begin match Sqlexpr.select db [%sqlc "SELECT @d{price} FROM foo WHERE %s"] (Printf.sprintf "name=%s" "table") with
  | [ p ] -> Printf.printf "ok\n"
  | _ -> Printf.printf "KO !\n"
  end;

Which upon execution returns:

ok
KO !

One could expect the two output lines to both be ok, however, it seems preformatting the condition into a string outside the sql query induces some kind of weird behavior.
Would it be possible to support this kind of sql statements ?

@j0sh
Copy link
Contributor

j0sh commented Aug 16, 2016

Don't think that is possible, since placeholders can only represent values (eg, substituting for literals), not predicates or other fragments of a SQL string.

@mfp
Copy link
Owner

mfp commented Aug 26, 2016

Not possible, for reasons similar to PG'OCaml's.
The way to support this would be to encode relational algebra using the type system and make queries composable, etc., which is diametrically opposed to sqlexpr's simple approach (accept anything you can express in Sqlite3's SQL dialect and just make prepared statements really easy to use while bringing some type-safety).

If you're interested in a composable approach, there's [https://github.com/ocsigen/macaque]. It works with PGOcaml, but it should be possible to adapt it to Sqlite3: it essentially builds a "raw" SQL query string and sends it to the DB. Replacing the string evaluation + output parsing function and tweaking the query generator would give you composable queries for Sqlite3.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants