Sha256: ea9062c25be7336f8e4a72260503f869d66999331106274abfba62bb93de9122

Contents?: true

Size: 1.45 KB

Versions: 20

Compression:

Stored size: 1.45 KB

Contents

Sequel.require 'adapters/shared/mssql'

module Sequel
  module JDBC
    class Database
      # Alias the generic JDBC version so it can be called directly later
      alias jdbc_schema_parse_table schema_parse_table
    end
    
    # Database and Dataset instance methods for MSSQL specific
    # support via JDBC.
    module MSSQL
      # Database instance methods for MSSQL databases accessed via JDBC.
      module DatabaseMethods
        extend Sequel::Database::ResetIdentifierMangling
        PRIMARY_KEY_INDEX_RE = /\Apk__/i.freeze
        ATAT_IDENTITY = 'SELECT @@IDENTITY'.freeze
        SCOPE_IDENTITY = 'SELECT SCOPE_IDENTITY()'.freeze
        
        include Sequel::MSSQL::DatabaseMethods
        
        private
        
        # Get the last inserted id using SCOPE_IDENTITY().
        def last_insert_id(conn, opts=OPTS)
          statement(conn) do |stmt|
            sql = opts[:prepared] ? ATAT_IDENTITY : SCOPE_IDENTITY
            rs = log_yield(sql){stmt.executeQuery(sql)}
            rs.next
            rs.getInt(1)
          end
        end
        
        # Call the generic JDBC version instead of MSSQL version,
        # since the JDBC version handles primary keys.
        def schema_parse_table(table, opts=OPTS)
          jdbc_schema_parse_table(table, opts)
        end
        
        # Primary key indexes appear to start with pk__ on MSSQL
        def primary_key_index_re
          PRIMARY_KEY_INDEX_RE
        end
      end
    end
  end
end

Version data entries

20 entries across 20 versions & 2 rubygems

Version Path
sequel-4.17.0 lib/sequel/adapters/jdbc/mssql.rb
sequel-4.16.0 lib/sequel/adapters/jdbc/mssql.rb
asana2flowdock-1.0.0 vendor/bundle/ruby/1.9.1/gems/sequel-4.15.0/lib/sequel/adapters/jdbc/mssql.rb
sequel-4.15.0 lib/sequel/adapters/jdbc/mssql.rb
sequel-4.14.0 lib/sequel/adapters/jdbc/mssql.rb
sequel-4.13.0 lib/sequel/adapters/jdbc/mssql.rb
sequel-4.12.0 lib/sequel/adapters/jdbc/mssql.rb
sequel-4.11.0 lib/sequel/adapters/jdbc/mssql.rb
sequel-4.10.0 lib/sequel/adapters/jdbc/mssql.rb
sequel-4.9.0 lib/sequel/adapters/jdbc/mssql.rb
sequel-4.8.0 lib/sequel/adapters/jdbc/mssql.rb
sequel-4.7.0 lib/sequel/adapters/jdbc/mssql.rb
sequel-4.6.0 lib/sequel/adapters/jdbc/mssql.rb
sequel-4.5.0 lib/sequel/adapters/jdbc/mssql.rb
sequel-4.4.0 lib/sequel/adapters/jdbc/mssql.rb
sequel-4.3.0 lib/sequel/adapters/jdbc/mssql.rb
sequel-4.2.0 lib/sequel/adapters/jdbc/mssql.rb
sequel-4.1.1 lib/sequel/adapters/jdbc/mssql.rb
sequel-4.1.0 lib/sequel/adapters/jdbc/mssql.rb
sequel-4.0.0 lib/sequel/adapters/jdbc/mssql.rb