Skip to content

Commit

Permalink
Fix Oracle issues
Browse files Browse the repository at this point in the history
  • Loading branch information
mayorova committed Dec 2, 2024
1 parent fbbe29d commit 61437ad
Show file tree
Hide file tree
Showing 2 changed files with 2 additions and 33 deletions.
2 changes: 1 addition & 1 deletion config/initializers/oracle.rb
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
require 'arel/visitors/oracle12_hack'

ENV['SCHEMA'] = 'db/oracle_schema.rb'
Rails.configuration.active_record.schema_format = ActiveRecord::Base.schema_format = :ruby
Rails.configuration.active_record.schema_format = ActiveRecord.schema_format = :ruby

ActiveRecord::ConnectionAdapters::TableDefinition.prepend(Module.new do
def column(name, type, **options)
Expand Down
33 changes: 1 addition & 32 deletions lib/arel/visitors/oracle12_hack.rb
Original file line number Diff line number Diff line change
Expand Up @@ -23,38 +23,7 @@ def visit_Arel_Nodes_NotIn(o, collector)
super
end

# Another wonderful piece.
# Oracle can't compare CLOB columns with standard SQL operators for comparison.
# We need to replace standard equality for text/binary columns to use DBMS_LOB.COMPARE function.
# Fixes ORA-00932: inconsistent datatypes: expected - got CLOB
# remove if https://github.com/rsim/oracle-enhanced/issues/2239 is fixed (in Rails 7.0.1)
def visit_Arel_Nodes_Equality(o, collector)
case (left = o.left)
when Arel::Attributes::Attribute
table = left.relation.table_name
schema_cache = @connection.schema_cache

return super unless schema_cache.data_source_exists?(table)

column = schema_cache.columns_hash(table)[left.name.to_s]

case column.type
when :text, :binary
# https://docs.oracle.com/cd/B19306_01/appdev.102/b14258/d_lob.htm#i1016668
# returns 0 when the comparison succeeds
comparator = Arel::Nodes::NamedFunction.new('DBMS_LOB.COMPARE', [left, o.right])
collector = visit comparator, collector
collector << ' = 0'
collector
else
super
end
else
super
end
end

# remove when addressed: https://github.com/rsim/oracle-enhanced/pull/2247
# remove when addressed: https://github.com/rsim/oracle-enhanced/pull/2247 - included in v7.1.0
def visit_Arel_Nodes_Matches o, collector
if !o.case_sensitive && o.left && o.right
o.left = Arel::Nodes::NamedFunction.new('UPPER', [o.left])
Expand Down

0 comments on commit 61437ad

Please sign in to comment.