Class | Sequel::JDBC::H2::Dataset |
In: |
lib/sequel/adapters/jdbc/h2.rb
|
Parent: | JDBC::Dataset |
SELECT_CLAUSE_METHODS | = | clause_methods(:select, %w'select distinct columns from join where group having compounds order limit') |
BITWISE_METHOD_MAP | = | {:& =>:BITAND, :| => :BITOR, :^ => :BITXOR} |
APOS | = | Dataset::APOS |
HSTAR | = | "H*".freeze |
BITCOMP_OPEN | = | "((0 - ".freeze |
BITCOMP_CLOSE | = | ") - 1)".freeze |
ILIKE_PLACEHOLDER | = | "CAST(? AS VARCHAR_IGNORECASE)".freeze |
TIME_FORMAT | = | "'%H:%M:%S'".freeze |
H2_CLOB_METHOD | = | TYPE_TRANSLATOR_INSTANCE.method(:h2_clob) |
Emulate the case insensitive LIKE operator and the bitwise operators.
# File lib/sequel/adapters/jdbc/h2.rb, line 131 131: def complex_expression_sql_append(sql, op, args) 132: case op 133: when :ILIKE, "NOT ILIKE""NOT ILIKE" 134: super(sql, (op == :ILIKE ? :LIKE : "NOT LIKE""NOT LIKE"), [SQL::PlaceholderLiteralString.new(ILIKE_PLACEHOLDER, [args.at(0)]), args.at(1)]) 135: when :&, :|, :^ 136: sql << complex_expression_arg_pairs(args){|a, b| literal(SQL::Function.new(BITWISE_METHOD_MAP[op], a, b))} 137: when :<< 138: sql << complex_expression_arg_pairs(args){|a, b| "(#{literal(a)} * POWER(2, #{literal(b)}))"} 139: when :>> 140: sql << complex_expression_arg_pairs(args){|a, b| "(#{literal(a)} / POWER(2, #{literal(b)}))"} 141: when 'B~''B~' 142: sql << BITCOMP_OPEN 143: literal_append(sql, args.at(0)) 144: sql << BITCOMP_CLOSE 145: else 146: super 147: end 148: end