Module Sequel::SQLite::DatasetMethods
In: lib/sequel/adapters/shared/sqlite.rb

Instance methods for datasets that connect to an SQLite database

Methods

Constants

SELECT_CLAUSE_METHODS = Dataset.clause_methods(:select, %w'distinct columns from join where group having compounds order limit')
COMMA_SEPARATOR = ', '.freeze
CONSTANT_MAP = {:CURRENT_DATE=>"date(CURRENT_TIMESTAMP, 'localtime')".freeze, :CURRENT_TIMESTAMP=>"datetime(CURRENT_TIMESTAMP, 'localtime')".freeze, :CURRENT_TIME=>"time(CURRENT_TIMESTAMP, 'localtime')".freeze}

Public Instance methods

SQLite does not support pattern matching via regular expressions. SQLite is case insensitive (depending on pragma), so use LIKE for ILIKE.

[Source]

     # File lib/sequel/adapters/shared/sqlite.rb, line 327
327:       def complex_expression_sql(op, args)
328:         case op
329:         when :~, '!~''!~', '~*''~*', '!~*''!~*'
330:           raise Error, "SQLite does not support pattern matching via regular expressions"
331:         when :LIKE, 'NOT LIKE''NOT LIKE', :ILIKE, 'NOT ILIKE''NOT ILIKE'
332:           # SQLite is case insensitive for ASCII, and non case sensitive for other character sets
333:           "#{'NOT ' if [:'NOT LIKE', :'NOT ILIKE'].include?(op)}(#{literal(args.at(0))} LIKE #{literal(args.at(1))})"
334:         else
335:           super(op, args)
336:         end
337:       end

MSSQL doesn‘t support the SQL standard CURRENT_DATE or CURRENT_TIME

[Source]

     # File lib/sequel/adapters/shared/sqlite.rb, line 340
340:       def constant_sql(constant)
341:         CONSTANT_MAP[constant] || super
342:       end

SQLite performs a TRUNCATE style DELETE if no filter is specified. Since we want to always return the count of records, add a condition that is always true and then delete.

[Source]

     # File lib/sequel/adapters/shared/sqlite.rb, line 347
347:       def delete
348:         @opts[:where] ? super : filter(1=>1).delete
349:       end

Return an array of strings specifying a query explanation for a SELECT of the current dataset.

[Source]

     # File lib/sequel/adapters/shared/sqlite.rb, line 353
353:       def explain
354:         db.send(:metadata_dataset).clone(:sql=>"EXPLAIN #{select_sql}").
355:           map{|x| "#{x[:addr]}|#{x[:opcode]}|#{(1..5).map{|i| x[:"p#{i}"]}.join('|')}|#{x[:comment]}"}
356:       end

HAVING requires GROUP BY on SQLite

[Source]

     # File lib/sequel/adapters/shared/sqlite.rb, line 359
359:       def having(*cond)
360:         raise(InvalidOperation, "Can only specify a HAVING clause on a grouped dataset") unless @opts[:group]
361:         super
362:       end

SQLite uses the nonstandard ` (backtick) for quoting identifiers.

[Source]

     # File lib/sequel/adapters/shared/sqlite.rb, line 365
365:       def quoted_identifier(c)
366:         "`#{c}`"
367:       end

SQLite does not support INTERSECT ALL or EXCEPT ALL

[Source]

     # File lib/sequel/adapters/shared/sqlite.rb, line 370
370:       def supports_intersect_except_all?
371:         false
372:       end

SQLite does not support IS TRUE

[Source]

     # File lib/sequel/adapters/shared/sqlite.rb, line 375
375:       def supports_is_true?
376:         false
377:       end

SQLite does not support multiple columns for the IN/NOT IN operators

[Source]

     # File lib/sequel/adapters/shared/sqlite.rb, line 380
380:       def supports_multiple_column_in?
381:         false
382:       end

SQLite supports timezones in literal timestamps, since it stores them as text.

[Source]

     # File lib/sequel/adapters/shared/sqlite.rb, line 386
386:       def supports_timestamp_timezones?
387:         true
388:       end

[Validate]