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
tdiary-5.1.2 vendor/bundle/ruby/2.7.0/gems/sequel-5.32.0/lib/sequel/adapters/ado/mssql.rb
tdiary-5.1.2 vendor/bundle/ruby/2.6.0/gems/sequel-5.26.0/lib/sequel/adapters/ado/mssql.rb
sequel-5.32.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.31.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.30.0 lib/sequel/adapters/ado/mssql.rb
tdiary-5.1.1 vendor/bundle/ruby/2.6.0/gems/sequel-5.26.0/lib/sequel/adapters/ado/mssql.rb
tdiary-5.1.1 vendor/bundle/ruby/2.7.0/gems/sequel-5.29.0/lib/sequel/adapters/ado/mssql.rb
sequel-5.29.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.28.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.27.0 lib/sequel/adapters/ado/mssql.rb
tdiary-5.1.0 vendor/bundle/gems/sequel-5.26.0/lib/sequel/adapters/ado/mssql.rb
sequel-5.26.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.25.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.24.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.23.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.22.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.21.0 lib/sequel/adapters/ado/mssql.rb
sequel-5.20.0 lib/sequel/adapters/ado/mssql.rb
tdiary-5.0.13 vendor/bundle/gems/sequel-5.18.0/lib/sequel/adapters/ado/mssql.rb
sequel-5.19.0 lib/sequel/adapters/ado/mssql.rb