ipgsql.erl 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. %%% Copyright (C) 2011 - Anton Lebedevich. All rights reserved.
  2. -module(ipgsql).
  3. -export([start_link/0,
  4. connect/2, connect/3, connect/4, connect/5,
  5. close/1,
  6. get_parameter/2,
  7. squery/2,
  8. equery/2, equery/3,
  9. parse/2, parse/3, parse/4,
  10. describe/2, describe/3,
  11. bind/3, bind/4,
  12. execute/2, execute/3, execute/4,
  13. execute_batch/2,
  14. close/2, close/3,
  15. sync/1,
  16. cancel/1]).
  17. -include("pgsql.hrl").
  18. %% -- client interface --
  19. start_link() ->
  20. pgsql_sock:start_link().
  21. connect(Host, Opts) ->
  22. connect(Host, os:getenv("USER"), "", Opts).
  23. connect(Host, Username, Opts) ->
  24. connect(Host, Username, "", Opts).
  25. connect(Host, Username, Password, Opts) ->
  26. {ok, C} = pgsql_sock:start_link(),
  27. connect(C, Host, Username, Password, Opts).
  28. connect(C, Host, Username, Password, Opts) ->
  29. incremental(C, {connect, Host, Username, Password, Opts}).
  30. close(C) ->
  31. pgsql_sock:close(C).
  32. get_parameter(C, Name) ->
  33. pgsql_sock:get_parameter(C, Name).
  34. squery(C, Sql) ->
  35. incremental(C, {squery, Sql}).
  36. equery(C, Sql) ->
  37. equery(C, Sql, []).
  38. equery(C, Statement, Parameters) ->
  39. incremental(C, {equery, Statement, Parameters}).
  40. parse(C, Sql) ->
  41. parse(C, "", Sql, []).
  42. parse(C, Sql, Types) ->
  43. parse(C, "", Sql, Types).
  44. parse(C, Name, Sql, Types) ->
  45. incremental(C, {parse, Name, Sql, Types}).
  46. bind(C, Statement, Parameters) ->
  47. bind(C, Statement, "", Parameters).
  48. bind(C, Statement, PortalName, Parameters) ->
  49. incremental(C, {bind, Statement, PortalName, Parameters}).
  50. execute(C, S) ->
  51. execute(C, S, "", 0).
  52. execute(C, S, N) ->
  53. execute(C, S, "", N).
  54. execute(C, Statement, PortalName, MaxRows) ->
  55. incremental(C, {execute, Statement, PortalName, MaxRows}).
  56. execute_batch(C, Batch) ->
  57. incremental(C, {execute_batch, Batch}).
  58. describe(C, #statement{name = Name}) ->
  59. describe(C, statement, Name).
  60. describe(C, statement, Name) ->
  61. incremental(C, {describe_statement, Name});
  62. describe(C, portal, Name) ->
  63. incremental(C, {describe_portal, Name}).
  64. close(C, #statement{name = Name}) ->
  65. close(C, statement, Name).
  66. close(C, Type, Name) ->
  67. incremental(C, {close, Type, Name}).
  68. sync(C) ->
  69. incremental(C, sync).
  70. cancel(C) ->
  71. pgsql_sock:cancel(C).
  72. %% -- internal functions --
  73. incremental(C, Command) ->
  74. Ref = make_ref(),
  75. gen_server:cast(C, {{incremental, self(), Ref}, Command}),
  76. Ref.