So I have a create_table like this for Courses at a School:
create_table :courses do |t|
  t.string :name
  t.references :course
  t.timestamps
end
         
        I think this thread has a different more Rails-ish way: Scaffolding ActiveRecord: two columns of the same data type
In the migration:
t.belongs_to :transferrable_as
t.belongs_to :same_as
As an added answer to this question -- the Model should have the following line to complete the association:
    belongs_to :transferrable_as, class_name: "Course"
    belongs_to :same_as, class_name: "Course"
                                                                        I don't think references accepts the :as option, but you can create your columns manually...
create_table :courses do |t| 
  t.string  :name 
  t.integer :course1_id
  t.integer :course2_id 
  t.timestamps 
end 
                                                                        You can do it this way:
create_table :courses do |t|
  t.string :name
  t.references :transferrable_as
  t.references :same_as
  t.timestamps
end
or using t.belongs_to as an alias for t.references
You can't add foreign_key: true to those two references lines. If you want to mark them as foreign keys at the database level you need to have a migration with this:
add_foreign_key :courses, :courses, column: :transferrable_as_id
add_foreign_key :courses, :courses, column: :same_as_id
In Rails 5.1 and above you can add the foreign key in the migration in the create_table block like this:
create_table :courses do |t|
  t.string :name
  t.references :transferrable_as, foreign_key: { to_table: 'courses' }
  t.references :same_as, foreign_key: { to_table: 'courses' }
  t.timestamps
end
                                                                        You can do this all in the initial migration/column definition (at least currently in Rails 5):
t.references :transferable_as, index: true, foreign_key: {to_table: :courses}
t.references :same_as, index: true, foreign_key: {to_table: :courses}