c099b41796
- Meter.addressId (FK → Address, ON DELETE SET NULL) + Migration 20260530100000_meter_address mit IF NOT EXISTS - Service erzwingt beim Create: Lieferadresse vorhanden + zum Kunden gehörig + Typ DELIVERY_RESIDENCE - MeterModal: Pflicht-Dropdown "Lieferadresse"; Save disabled ohne Adresse; Hinweis-Banner. Bestandszähler ohne Adresse zeigen "nicht zugeordnet – bitte über Bearbeiten nachpflegen" - ContractForm: Zähler-Dropdown filtert auf Vertrags-Lieferadresse; deaktivierte Zähler bleiben sichtbar mit "(deaktiviert)"; bei Auswahl Toast-Warnung wegen möglichem Altvertrag Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
44 lines
1.4 KiB
SQL
44 lines
1.4 KiB
SQL
-- 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;
|