JNDI_URI_REGEXP | = | /\Ajdbc:jndi:(.+)/ | Used to identify a jndi connection and to extract the jndi resource name. | |
DATABASE_SETUP | = | {} | Contains procs keyed on subadapter type that extend the given database object so it supports the correct database type. | |
StoredProcedureMethods | = | prepared_statements_module( "sql = @opts[:sproc_name]; opts = Hash[opts]; opts[:args] = @opts[:sproc_args]; opts[:sproc] = true", Sequel::Dataset::StoredProcedureMethods, %w"execute execute_dui") do private |
schema_parse_table | -> | jdbc_schema_parse_table |
tables | -> | jdbc_tables |
views | -> | jdbc_views |
indexes | -> | jdbc_indexes |
jdbc_schema_parse_table | -> | schema_parse_table |
jdbc_tables | -> | tables |
jdbc_views | -> | views |
jdbc_indexes | -> | indexes |
Attempt to load the JDBC driver class, which should be specified as a string containing the driver class name (which JRuby should autoload). Note that the string is evaled, so this method is not safe to call with untrusted input. Raise a Sequel::AdapterNotFound if evaluating the class name raises a NameError.
# File lib/sequel/adapters/jdbc.rb, line 40 40: def self.load_driver(drv, gem=nil) 41: load_gem(gem) if gem 42: eval drv 43: rescue NameError 44: raise Sequel::AdapterNotFound, "#{drv} not loaded#{", try installing jdbc-#{gem.to_s.downcase} gem" if gem}" 45: end
Allow loading the necessary JDBC support via a gem.
# File lib/sequel/adapters/jdbc.rb, line 22 22: def self.load_gem(name) 23: begin 24: require "jdbc/#{name.to_s.downcase}" 25: rescue LoadError 26: # jdbc gem not used, hopefully the user has the .jar in their CLASSPATH 27: else 28: if defined?(::Jdbc) && ( ::Jdbc.const_defined?(name) rescue nil ) 29: jdbc_module = ::Jdbc.const_get(name) # e.g. Jdbc::SQLite3 30: jdbc_module.load_driver if jdbc_module.respond_to?(:load_driver) 31: end 32: end 33: end