mirror of
https://github.com/simstudioai/sim.git
synced 2026-01-09 23:17:59 -05:00
48 lines
1.7 KiB
SQL
48 lines
1.7 KiB
SQL
-- Step 1: Add workspace_id as nullable first
|
|
ALTER TABLE "memory" ADD COLUMN "workspace_id" text;
|
|
|
|
-- Step 2: Backfill workspace_id from workflow's workspace_id
|
|
UPDATE memory m
|
|
SET workspace_id = w.workspace_id
|
|
FROM workflow w
|
|
WHERE m.workflow_id = w.id
|
|
AND w.workspace_id IS NOT NULL;
|
|
|
|
-- Step 3: Delete rows where workspace_id couldn't be resolved
|
|
DELETE FROM memory WHERE workspace_id IS NULL;
|
|
|
|
-- Step 4: Now make workspace_id NOT NULL
|
|
ALTER TABLE "memory" ALTER COLUMN "workspace_id" SET NOT NULL;
|
|
|
|
-- Step 5: Drop old constraint and indexes
|
|
ALTER TABLE "memory" DROP CONSTRAINT IF EXISTS "memory_workflow_id_workflow_id_fk";
|
|
--> statement-breakpoint
|
|
DROP INDEX IF EXISTS "memory_workflow_idx";
|
|
--> statement-breakpoint
|
|
DROP INDEX IF EXISTS "memory_workflow_key_idx";
|
|
|
|
-- Step 6: Deduplicate memory entries before creating unique index
|
|
-- Keep only the most recently updated entry for each (workspace_id, key) pair
|
|
DELETE FROM memory m1
|
|
USING memory m2
|
|
WHERE m1.workspace_id = m2.workspace_id
|
|
AND m1.key = m2.key
|
|
AND m1.updated_at < m2.updated_at;
|
|
|
|
-- Handle ties by keeping the one with the smaller id
|
|
DELETE FROM memory m1
|
|
USING memory m2
|
|
WHERE m1.workspace_id = m2.workspace_id
|
|
AND m1.key = m2.key
|
|
AND m1.id > m2.id;
|
|
|
|
-- Step 7: Add new foreign key and indexes
|
|
ALTER TABLE "memory" ADD CONSTRAINT "memory_workspace_id_workspace_id_fk" FOREIGN KEY ("workspace_id") REFERENCES "public"."workspace"("id") ON DELETE cascade ON UPDATE no action;
|
|
--> statement-breakpoint
|
|
CREATE INDEX "memory_workspace_idx" ON "memory" USING btree ("workspace_id");
|
|
--> statement-breakpoint
|
|
CREATE UNIQUE INDEX "memory_workspace_key_idx" ON "memory" USING btree ("workspace_id","key");
|
|
|
|
-- Step 8: Drop old column
|
|
ALTER TABLE "memory" DROP COLUMN IF EXISTS "workflow_id";
|