Class: SQLRunner::Adapters::MySQL
- Inherits:
-
Object
- Object
- SQLRunner::Adapters::MySQL
- Defined in:
- lib/sql_runner/adapters/mysql.rb
Constant Summary collapse
- InvalidPreparedStatement =
Class.new(StandardError)
Class Method Summary collapse
Instance Method Summary collapse
- #active? ⇒ Boolean
- #connect(started = Process.clock_gettime(Process::CLOCK_MONOTONIC)) ⇒ Object
- #disconnect ⇒ Object
- #execute(query, **bind_vars) ⇒ Object
-
#initialize(connection_string) ⇒ MySQL
constructor
A new instance of MySQL.
- #inspect ⇒ Object
- #parse(query, bind_vars) ⇒ Object
- #reconnect ⇒ Object
- #to_s ⇒ Object
Constructor Details
#initialize(connection_string) ⇒ MySQL
Returns a new instance of MySQL.
14 15 16 17 18 |
# File 'lib/sql_runner/adapters/mysql.rb', line 14 def initialize(connection_string) @connection_string = connection_string @uri = URI.parse(@connection_string) connect end |
Class Method Details
.load ⇒ Object
8 9 10 11 12 |
# File 'lib/sql_runner/adapters/mysql.rb', line 8 def self.load require "mysql2" rescue LoadError raise MissingDependency, "make sure the `mysql2` gem is available" end |
Instance Method Details
#active? ⇒ Boolean
57 58 59 60 61 |
# File 'lib/sql_runner/adapters/mysql.rb', line 57 def active? !@connection&.closed? rescue Mysql2::Error false end |
#connect(started = Process.clock_gettime(Process::CLOCK_MONOTONIC)) ⇒ Object
20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 |
# File 'lib/sql_runner/adapters/mysql.rb', line 20 def connect(started = Process.clock_gettime(Process::CLOCK_MONOTONIC)) @connection = Mysql2::Client.new( host: @uri.host, port: @uri.port, username: @uri.user, password: @uri.password, database: @uri.path[1..-1] ) rescue Mysql2::Error ended = Process.clock_gettime(Process::CLOCK_MONOTONIC) raise unless ended - started < SQLRunner.timeout sleep 0.1 connect(started) end |
#disconnect ⇒ Object
37 38 39 |
# File 'lib/sql_runner/adapters/mysql.rb', line 37 def disconnect @connection&.close && (@connection = nil) end |
#execute(query, **bind_vars) ⇒ Object
46 47 48 49 50 51 52 53 54 55 |
# File 'lib/sql_runner/adapters/mysql.rb', line 46 def execute(query, **bind_vars) bound_query, bindings, names = parse(query, bind_vars) validate_bindings(query, bind_vars, names) statement = @connection.prepare(bound_query) statement.execute(*bindings, cast: true) rescue Mysql2::Error reconnect execute(query, **bind_vars) end |
#inspect ⇒ Object
67 68 69 |
# File 'lib/sql_runner/adapters/mysql.rb', line 67 def inspect to_s end |
#parse(query, bind_vars) ⇒ Object
71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 |
# File 'lib/sql_runner/adapters/mysql.rb', line 71 def parse(query, bind_vars) bindings = [] names = [] parsed_query = query.gsub(/(:?):([a-zA-Z]\w*)/) do |match| next match if Regexp.last_match(1) == ":" # skip type casting name = match[1..-1] sym_name = name.to_sym names << sym_name bindings << bind_vars[sym_name] "?" end [parsed_query, bindings, names] end |
#reconnect ⇒ Object
41 42 43 44 |
# File 'lib/sql_runner/adapters/mysql.rb', line 41 def reconnect disconnect connect end |
#to_s ⇒ Object
63 64 65 |
# File 'lib/sql_runner/adapters/mysql.rb', line 63 def to_s %[#<#{self.class.name} #{format('0x00%x', (object_id << 1))}>] end |