sql.hrl 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. -include("metainfo.hrl").
  2. % MEKAO SQL
  3. -record(sql_select, {table,columns,where,order_by}).
  4. -record(sql_insert, {table,columns,values,returning}).
  5. -record(sql_update, {table,set,where,returning}).
  6. -record(sql_delete, {table,where,returning}).
  7. -record(sql_settings, {placeholder,returning,is_null = fun(X) -> X == undefined end}).
  8. -spec insert(entity(), table(), s()) -> {ok, b_query()} | {error, empty_insert}.
  9. -spec select_pk(selector(), table(), s()) -> {ok, b_query()} | {error, pk_miss}.
  10. -spec select(selector(), table(), s()) -> {ok, b_query()}.
  11. -spec update_pk(selector(), table(), s()) -> {ok, b_query()} | {error, pk_miss} | {error, empty_update}.
  12. -spec update_pk_diff( Old :: entity(), New :: entity(), table(), s()) -> {ok, b_query()} | {error, pk_miss} | {error, empty_update}.
  13. -spec update(entity(), selector(), table(), s()) -> {ok, b_query()} | {error, empty_update}.
  14. -spec delete_pk(selector(), table(), s()) -> {ok, b_query()} | {error, pk_miss}.
  15. -spec delete(selector(), table(), s()) -> {ok, b_query()}.
  16. -spec prepare_insert(entity(), table(), s()) -> p_query().
  17. -spec prepare_select(selector(), table(), s()) -> p_query().
  18. -spec prepare_delete(selector(), table(), s()) -> p_query().
  19. -spec prepare_update(entity(), selector(), table(), s()) -> p_query().
  20. -spec returning(insert | update | delete, table(), s()) -> iolist().
  21. -spec build(p_query()) -> b_query().
  22. -type b_query() :: 'query'(iolist()).
  23. -type table() :: #table{}.
  24. -type column() :: #column{}.
  25. -type s() :: #sql_settings{}.
  26. -type entity() :: tuple() | list().
  27. -type selector() :: tuple() | list(predicate(term())).
  28. -type predicate(Value) :: Value | { '$predicate', '=' | '<>' | '>' | '>=' | '<' | '<=', Value}.
  29. -type 'query'(Body) :: #query{body :: Body}.
  30. -type p_query() :: 'query'( #sql_insert{}
  31. | #sql_select{}
  32. | #sql_update{}
  33. | #sql_delete{}
  34. ).
  35. -export_type([
  36. table/0, column/0, s/0,
  37. p_query/0, b_query/0,
  38. predicate/1
  39. ]).