Class: ClickhouseNative::Pool
- Inherits:
-
Object
- Object
- ClickhouseNative::Pool
- Defined in:
- lib/clickhouse_native/pool.rb
Instance Attribute Summary collapse
-
#database ⇒ Object
readonly
Returns the value of attribute database.
-
#host ⇒ Object
readonly
Returns the value of attribute host.
-
#port ⇒ Object
readonly
Returns the value of attribute port.
Instance Method Summary collapse
- #describe_table(table, db_name: nil) ⇒ Object
- #execute(sql) ⇒ Object
-
#initialize(host:, port:, database: "default", user: "default", password: "", compression: :none, logger: nil, settings: {}, pool_size: 5, pool_timeout: 5) ⇒ Pool
constructor
A new instance of Pool.
- #insert(table, rows, **opts) ⇒ Object
- #ping ⇒ Object
- #query(sql) ⇒ Object
- #query_each(sql, &block) ⇒ Object
- #query_value(sql) ⇒ Object
- #server_version ⇒ Object
- #with ⇒ Object
Constructor Details
#initialize(host:, port:, database: "default", user: "default", password: "", compression: :none, logger: nil, settings: {}, pool_size: 5, pool_timeout: 5) ⇒ Pool
Returns a new instance of Pool.
9 10 11 12 13 14 15 16 17 18 19 20 21 22 |
# File 'lib/clickhouse_native/pool.rb', line 9 def initialize(host:, port:, database: "default", user: "default", password: "", compression: :none, logger: nil, settings: {}, pool_size: 5, pool_timeout: 5) @host = host @port = port @database = database client_kwargs = { host:, port:, database:, user:, password:, compression:, logger: } set_sql = settings_sql(settings) @pool = ConnectionPool.new(size: pool_size, timeout: pool_timeout) do client = Client.new(**client_kwargs) client.execute(set_sql) if set_sql client end end |
Instance Attribute Details
#database ⇒ Object (readonly)
Returns the value of attribute database.
7 8 9 |
# File 'lib/clickhouse_native/pool.rb', line 7 def database @database end |
#host ⇒ Object (readonly)
Returns the value of attribute host.
7 8 9 |
# File 'lib/clickhouse_native/pool.rb', line 7 def host @host end |
#port ⇒ Object (readonly)
Returns the value of attribute port.
7 8 9 |
# File 'lib/clickhouse_native/pool.rb', line 7 def port @port end |
Instance Method Details
#describe_table(table, db_name: nil) ⇒ Object
56 57 58 |
# File 'lib/clickhouse_native/pool.rb', line 56 def describe_table(table, db_name: nil) @pool.with { |c| c.describe_table(table, db_name:) } end |
#execute(sql) ⇒ Object
28 29 30 |
# File 'lib/clickhouse_native/pool.rb', line 28 def execute(sql) @pool.with { |c| c.execute(sql) } end |
#insert(table, rows, **opts) ⇒ Object
44 45 46 |
# File 'lib/clickhouse_native/pool.rb', line 44 def insert(table, rows, **opts) @pool.with { |c| c.insert(table, rows, **opts) } end |
#ping ⇒ Object
48 49 50 |
# File 'lib/clickhouse_native/pool.rb', line 48 def ping @pool.with(&:ping) end |
#query(sql) ⇒ Object
32 33 34 |
# File 'lib/clickhouse_native/pool.rb', line 32 def query(sql) @pool.with { |c| c.query(sql) } end |
#query_each(sql, &block) ⇒ Object
36 37 38 |
# File 'lib/clickhouse_native/pool.rb', line 36 def query_each(sql, &block) @pool.with { |c| c.query_each(sql, &block) } end |
#query_value(sql) ⇒ Object
40 41 42 |
# File 'lib/clickhouse_native/pool.rb', line 40 def query_value(sql) @pool.with { |c| c.query_value(sql) } end |
#server_version ⇒ Object
52 53 54 |
# File 'lib/clickhouse_native/pool.rb', line 52 def server_version @pool.with(&:server_version) end |
#with ⇒ Object
24 25 26 |
# File 'lib/clickhouse_native/pool.rb', line 24 def with(&) @pool.with(&) end |