db: add not-null constraints to AdministrateursInstructeur

This commit is contained in:
Pierre de La Morinerie 2022-03-22 12:31:34 +00:00
parent afcacfc8d4
commit 9dcd92a678
3 changed files with 15 additions and 5 deletions

View file

@ -4,8 +4,8 @@
# #
# created_at :datetime # created_at :datetime
# updated_at :datetime # updated_at :datetime
# administrateur_id :integer # administrateur_id :integer not null
# instructeur_id :integer # instructeur_id :integer not null
# #
class AdministrateursInstructeur < ApplicationRecord class AdministrateursInstructeur < ApplicationRecord
belongs_to :administrateur belongs_to :administrateur

View file

@ -0,0 +1,10 @@
class AddNotNullConstraintsToAdministrateursInstructeur < ActiveRecord::Migration[6.1]
def change
# We ignore strong_migrations safety warnings, because those tables are relatively small, and the null check
# will be very fast.
safety_assured do
change_column_null :administrateurs_instructeurs, :administrateur_id, false
change_column_null :administrateurs_instructeurs, :instructeur_id, false
end
end
end

View file

@ -10,7 +10,7 @@
# #
# It's strongly recommended that you check this file into your version control system. # It's strongly recommended that you check this file into your version control system.
ActiveRecord::Schema.define(version: 2022_03_15_113510) do ActiveRecord::Schema.define(version: 2022_03_22_110900) do
# These are extensions that must be enabled in order to support this database # These are extensions that must be enabled in order to support this database
enable_extension "plpgsql" enable_extension "plpgsql"
@ -64,9 +64,9 @@ ActiveRecord::Schema.define(version: 2022_03_15_113510) do
end end
create_table "administrateurs_instructeurs", id: false, force: :cascade do |t| create_table "administrateurs_instructeurs", id: false, force: :cascade do |t|
t.integer "administrateur_id" t.integer "administrateur_id", null: false
t.datetime "created_at" t.datetime "created_at"
t.integer "instructeur_id" t.integer "instructeur_id", null: false
t.datetime "updated_at" t.datetime "updated_at"
t.index ["administrateur_id"], name: "index_administrateurs_instructeurs_on_administrateur_id" t.index ["administrateur_id"], name: "index_administrateurs_instructeurs_on_administrateur_id"
t.index ["instructeur_id", "administrateur_id"], name: "unique_couple_administrateur_instructeur", unique: true t.index ["instructeur_id", "administrateur_id"], name: "unique_couple_administrateur_instructeur", unique: true