Sha256: 81d5f0b64b3ca75a19e5b66031cca2f5181db20a9b4504a7aa9b0ed06377bb54

Contents?: true

Size: 1.97 KB

Versions: 103

Compression:

Stored size: 1.97 KB

Contents

# frozen-string-literal: true

require_relative '../shared/mssql'

module Sequel
  module ADO
    module MSSQL
      module DatabaseMethods
        include Sequel::MSSQL::DatabaseMethods

        def execute_dui(sql, opts=OPTS)
          return super unless @opts[:provider]
          synchronize(opts[:server]) do |conn|
            begin
              sql = "SET NOCOUNT ON; #{sql}; SELECT @@ROWCOUNT"
              rst = log_connection_yield(sql, conn){conn.Execute(sql)}
              rst.GetRows[0][0]
            rescue ::WIN32OLERuntimeError => e
              raise_error(e)
            end
          end
        end

        private

        # The ADO adapter's default provider doesn't support transactions, since it 
        # creates a new native connection for each query.  So Sequel only attempts
        # to use transactions if an explicit :provider is given.
        def begin_transaction(conn, opts=OPTS)
          super if @opts[:provider]
        end

        def commit_transaction(conn, opts=OPTS)
          super if @opts[:provider]
        end

        def rollback_transaction(conn, opts=OPTS)
          super if @opts[:provider]
        end
      end
      
      class Dataset < ADO::Dataset
        include Sequel::MSSQL::DatasetMethods

        # Use a nasty hack of multiple SQL statements in the same call and
        # having the last one return the most recently inserted id.  This
        # is necessary as ADO's default :provider uses a separate native
        # connection for each query.
        def insert(*values)
          return super if (@opts[:sql] && !@opts[:prepared_sql]) || @opts[:returning]
          with_sql("SET NOCOUNT ON; #{insert_sql(*values)}; SELECT CAST(SCOPE_IDENTITY() AS INTEGER)").single_value
        end
        
        # If you use a better :provider option for the database, you can get an
        # accurate number of rows matched.
        def provides_accurate_rows_matched?
          !!db.opts[:provider]
        end
      end
    end
  end
end

Version data entries

103 entries across 89 versions & 2 rubygems

Version Path
sequel-5.88.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.87.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.86.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.85.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.84.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.83.1 lib/sequel/adapters/ado/mssql.rb
sequel-5.83.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.82.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.81.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.80.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.79.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.78.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.77.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.76.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.75.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.74.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.73.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.72.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.71.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.70.0 lib/sequel/adapters/ado/mssql.rb