| Module | Sequel::Plugins::ClassTableInheritance | 
| In: | lib/sequel/plugins/class_table_inheritance.rb | 
The class_table_inheritance plugin allows you to model inheritance in the database using a table per model class in the hierarchy, with only columns unique to that model class (or subclass hierarchy) being stored in the related table. For example, with this hierarchy:
                       Employee
                      /        \
                   Staff     Manager
                                |
                            Executive
the following database schema may be used (table - columns):
The class_table_inheritance plugin assumes that the main table (e.g. employees) has a primary key field (usually autoincrementing), and all other tables have a foreign key of the same name that points to the same key in their superclass‘s table. For example:
When using the class_table_inheritance plugin, subclasses use joined datasets:
  Employee.dataset.sql  # SELECT * FROM employees
  Manager.dataset.sql   # SELECT * FROM employees
                        # INNER JOIN managers USING (id)
  Executive.dataset.sql # SELECT * FROM employees
                        # INNER JOIN managers USING (id)
                        # INNER JOIN executives USING (id)
This allows Executive.all to return instances with all attributes loaded. The plugin overrides the deleting, inserting, and updating in the model to work with multiple tables, by handling each table individually.
This plugin allows the use of a :key option when loading to mark a column holding a class name. This allows methods on the superclass to return instances of specific subclasses. This plugin also requires the lazy_attributes plugin and uses it to return subclass specific attributes that would not be loaded when calling superclass methods (since those wouldn‘t join to the subclass tables). For example:
  a = Employee.all # [<#Staff>, <#Manager>, <#Executive>]
  a.first.values # {:id=>1, name=>'S', :kind=>'Staff'}
  a.first.manager_id # Loads the manager_id attribute from the database
    The class_table_inheritance plugin requires the lazy_attributes plugin to handle lazily-loaded attributes for subclass instances returned by superclass methods.
    # File lib/sequel/plugins/class_table_inheritance.rb, line 61
61:       def self.apply(model, opts={}, &block)
62:         model.plugin :lazy_attributes
63:       end
          Initialize the per-model data structures and set the dataset‘s row_proc to check for the :key option column for the type of class when loading objects. Options:
Example:
  class Employee < Sequel::Model
    plugin :class_table_inheritance, :key=>:kind, :table_map=>{:Staff=>:staff}
  end
          
          
    # File lib/sequel/plugins/class_table_inheritance.rb, line 78
78:       def self.configure(model, opts={}, &block)
79:         model.instance_eval do
80:           m = method(:constantize)
81:           @cti_base_model = self
82:           @cti_key = key = opts[:key] 
83:           @cti_tables = [table_name]
84:           @cti_columns = {table_name=>columns}
85:           @cti_table_map = opts[:table_map] || {}
86:           dataset.row_proc = lambda{|r| (m.call(r[key]) rescue model).load(r)}
87:         end
88:       end