| Module | Sequel::MSSQL::DatabaseMethods |
| In: |
lib/sequel/adapters/shared/mssql.rb
|
| AUTO_INCREMENT | = | 'IDENTITY(1,1)'.freeze | ||
| SERVER_VERSION_RE | = | /^(\d+)\.(\d+)\.(\d+)/.freeze | ||
| SERVER_VERSION_SQL | = | "SELECT CAST(SERVERPROPERTY('ProductVersion') AS varchar)".freeze | ||
| SQL_BEGIN | = | "BEGIN TRANSACTION".freeze | ||
| SQL_COMMIT | = | "COMMIT TRANSACTION".freeze | ||
| SQL_ROLLBACK | = | "IF @@TRANCOUNT > 0 ROLLBACK TRANSACTION".freeze | ||
| SQL_ROLLBACK_TO_SAVEPOINT | = | 'IF @@TRANCOUNT > 0 ROLLBACK TRANSACTION autopoint_%d'.freeze | ||
| SQL_SAVEPOINT | = | 'SAVE TRANSACTION autopoint_%d'.freeze | ||
| DECIMAL_TYPE_RE | = | /number|numeric|decimal/io | The types to check for 0 scale to transform :decimal types to :integer. |
The version of the MSSQL server, as an integer (e.g. 10001600 for SQL Server 2008 Express).
# File lib/sequel/adapters/shared/mssql.rb, line 25
25: def server_version(server=nil)
26: return @server_version if @server_version
27: @server_version = synchronize(server) do |conn|
28: (conn.server_version rescue nil) if conn.respond_to?(:server_version)
29: end
30: unless @server_version
31: m = SERVER_VERSION_RE.match(fetch(SERVER_VERSION_SQL).single_value.to_s)
32: @server_version = (m[1].to_i * 1000000) + (m[2].to_i * 10000) + m[3].to_i
33: end
34: @server_version
35: end
Microsoft SQL Server supports using the INFORMATION_SCHEMA to get information on tables.
# File lib/sequel/adapters/shared/mssql.rb, line 49
49: def tables(opts={})
50: m = output_identifier_meth
51: metadata_dataset.from(:information_schema__tables___t).
52: select(:table_name).
53: filter(:table_type=>'BASE TABLE', :table_schema=>(opts[:schema]||default_schema||'dbo').to_s).
54: map{|x| m.call(x[:table_name])}
55: end