-- Zähler bekommen eine Lieferadresse, an der sie installiert sind. -- Optional, damit Bestandszähler (vor diesem Feature) nicht brechen – -- die werden manuell nachgepflegt. ON DELETE SET NULL, damit ein -- gelöschter Adresseintrag den Zähler nicht killt. -- -- IF NOT EXISTS macht den Re-Deploy auf Prod sicher, falls jemand schon -- `prisma db push` gefahren hat. ALTER TABLE `Meter` ADD COLUMN IF NOT EXISTS `addressId` INT NULL; -- Index nur anlegen, wenn er noch nicht da ist SET @idx_exists := ( SELECT COUNT(*) FROM information_schema.STATISTICS WHERE TABLE_SCHEMA = DATABASE() AND TABLE_NAME = 'Meter' AND INDEX_NAME = 'Meter_addressId_fkey' ); SET @sql := IF( @idx_exists = 0, 'CREATE INDEX `Meter_addressId_fkey` ON `Meter`(`addressId`)', 'SELECT "Index existiert bereits"' ); PREPARE stmt FROM @sql; EXECUTE stmt; DEALLOCATE PREPARE stmt; -- Foreign Key nur anlegen, wenn er noch nicht da ist SET @fk_exists := ( SELECT COUNT(*) FROM information_schema.TABLE_CONSTRAINTS WHERE TABLE_SCHEMA = DATABASE() AND TABLE_NAME = 'Meter' AND CONSTRAINT_NAME = 'Meter_addressId_fkey' AND CONSTRAINT_TYPE = 'FOREIGN KEY' ); SET @sql := IF( @fk_exists = 0, 'ALTER TABLE `Meter` ADD CONSTRAINT `Meter_addressId_fkey` FOREIGN KEY (`addressId`) REFERENCES `Address`(`id`) ON DELETE SET NULL ON UPDATE CASCADE', 'SELECT "FK existiert bereits"' ); PREPARE stmt FROM @sql; EXECUTE stmt; DEALLOCATE PREPARE stmt;