ipgsql.erl 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. %%% Copyright (C) 2011 - Anton Lebedevich. All rights reserved.
  2. -module(ipgsql).
  3. -export([start_link/0,
  4. connect/5,
  5. close/1,
  6. get_parameter/2,
  7. squery/2,
  8. equery/3,
  9. parse/4,
  10. bind/4,
  11. execute/4,
  12. execute_batch/2,
  13. describe/3,
  14. close/3,
  15. sync/1,
  16. cancel/1]).
  17. %% -- client interface --
  18. start_link() ->
  19. pgsql_sock:start_link().
  20. connect(C, Host, Username, Password, Opts) ->
  21. incremental(C, {connect, Host, Username, Password, Opts}).
  22. close(C) ->
  23. pgsql_sock:close(C).
  24. get_parameter(C, Name) ->
  25. pgsql_sock:get_parameter(C, Name).
  26. squery(C, Sql) ->
  27. incremental(C, {squery, Sql}).
  28. equery(C, Statement, Parameters) ->
  29. incremental(C, {equery, Statement, Parameters}).
  30. parse(C, Name, Sql, Types) ->
  31. incremental(C, {parse, Name, Sql, Types}).
  32. bind(C, Statement, PortalName, Parameters) ->
  33. incremental(C, {bind, Statement, PortalName, Parameters}).
  34. execute(C, Statement, PortalName, MaxRows) ->
  35. incremental(C, {execute, Statement, PortalName, MaxRows}).
  36. execute_batch(C, Batch) ->
  37. incremental(C, {execute_batch, Batch}).
  38. describe(C, statement, Name) ->
  39. incremental(C, {describe_statement, Name});
  40. describe(C, portal, Name) ->
  41. incremental(C, {describe_portal, Name}).
  42. close(C, Type, Name) ->
  43. incremental(C, {close, Type, Name}).
  44. sync(C) ->
  45. incremental(C, sync).
  46. cancel(C) ->
  47. pgsql_sock:cancel(C).
  48. %% -- internal functions --
  49. incremental(C, Command) ->
  50. Ref = make_ref(),
  51. gen_server:cast(C, {{incremental, self(), Ref}, Command}),
  52. Ref.