Sha256: f6e43c16bd95b852185f39307fc43611c34e75e49387fd5d23e1a6bd066d1f76

Contents?: true

Size: 1.39 KB

Versions: 5

Compression:

Stored size: 1.39 KB

Contents

# frozen-string-literal: true

require 'swift/db/mysql'
Sequel.require 'adapters/shared/mysql'

module Sequel
  module Swift
    # Database and Dataset instance methods for MySQL specific
    # support via Swift.
    module MySQL
      # Database instance methods for MySQL databases accessed via Swift.
      module DatabaseMethods
        include Sequel::MySQL::DatabaseMethods
        
        private
        
        # The database name for the given database.
        def database_name
          opts[:database]
        end

        # Consider tinyint(1) columns as boolean.
        def schema_column_type(db_type)
          db_type =~ /\Atinyint\(1\)/ ? :boolean : super
        end
      
        # Apply the connectiong setting SQLs for every new connection.
        def setup_connection(conn)
          mysql_connection_setting_sqls.each{|sql| log_connection_yield(sql, conn){conn.execute(sql)}}
          super
        end
      end
      
      # Dataset class for MySQL datasets accessed via Swift.
      class Dataset < Swift::Dataset
        include Sequel::MySQL::DatasetMethods

        APOS = "'".freeze
        Sequel::Deprecation.deprecate_constant(self, :APOS)
        
        private
        
        # Use Swift's escape method for quoting.
        def literal_string_append(sql, s)
          sql << "'" << db.synchronize(@opts[:server]){|c| c.escape(s)} << "'"
        end
      end
    end
  end
end

Version data entries

5 entries across 5 versions & 2 rubygems

Version Path
sequel-4.49.0 lib/sequel/adapters/swift/mysql.rb
sequel-4.48.0 lib/sequel/adapters/swift/mysql.rb
tdiary-5.0.5 vendor/bundle/gems/sequel-4.47.0/lib/sequel/adapters/swift/mysql.rb
sequel-4.47.0 lib/sequel/adapters/swift/mysql.rb
sequel-4.46.0 lib/sequel/adapters/swift/mysql.rb