86 lines
4.8 KiB
MySQL
86 lines
4.8 KiB
MySQL
|
|
-- Phase 2.3: Add user_role_profile_id to extension tables
|
||
|
|
-- Migration: 20260415010003
|
||
|
|
-- This links existing extension tables to the new user_role_profiles root
|
||
|
|
|
||
|
|
-- photographer_profiles
|
||
|
|
ALTER TABLE photographer_profiles ADD COLUMN IF NOT EXISTS user_role_profile_id UUID;
|
||
|
|
UPDATE photographer_profiles p SET user_role_profile_id = urp.id
|
||
|
|
FROM user_role_profiles urp
|
||
|
|
WHERE p.user_id = urp.user_id AND urp.role_key = 'photographer';
|
||
|
|
ALTER TABLE photographer_profiles ALTER COLUMN user_role_profile_id SET NOT NULL;
|
||
|
|
|
||
|
|
-- tutor_profiles
|
||
|
|
ALTER TABLE tutor_profiles ADD COLUMN IF NOT EXISTS user_role_profile_id UUID;
|
||
|
|
UPDATE tutor_profiles p SET user_role_profile_id = urp.id
|
||
|
|
FROM user_role_profiles urp
|
||
|
|
WHERE p.user_id = urp.user_id AND urp.role_key = 'tutor';
|
||
|
|
ALTER TABLE tutor_profiles ALTER COLUMN user_role_profile_id SET NOT NULL;
|
||
|
|
|
||
|
|
-- makeup_artist_profiles
|
||
|
|
ALTER TABLE makeup_artist_profiles ADD COLUMN IF NOT EXISTS user_role_profile_id UUID;
|
||
|
|
UPDATE makeup_artist_profiles p SET user_role_profile_id = urp.id
|
||
|
|
FROM user_role_profiles urp
|
||
|
|
WHERE p.user_id = urp.user_id AND urp.role_key = 'makeup_artist';
|
||
|
|
ALTER TABLE makeup_artist_profiles ALTER COLUMN user_role_profile_id SET NOT NULL;
|
||
|
|
|
||
|
|
-- developer_profiles
|
||
|
|
ALTER TABLE developer_profiles ADD COLUMN IF NOT EXISTS user_role_profile_id UUID;
|
||
|
|
UPDATE developer_profiles p SET user_role_profile_id = urp.id
|
||
|
|
FROM user_role_profiles urp
|
||
|
|
WHERE p.user_id = urp.user_id AND urp.role_key = 'developer';
|
||
|
|
ALTER TABLE developer_profiles ALTER COLUMN user_role_profile_id SET NOT NULL;
|
||
|
|
|
||
|
|
-- video_editor_profiles
|
||
|
|
ALTER TABLE video_editor_profiles ADD COLUMN IF NOT EXISTS user_role_profile_id UUID;
|
||
|
|
UPDATE video_editor_profiles p SET user_role_profile_id = urp.id
|
||
|
|
FROM user_role_profiles urp
|
||
|
|
WHERE p.user_id = urp.user_id AND urp.role_key = 'video_editor';
|
||
|
|
ALTER TABLE video_editor_profiles ALTER COLUMN user_role_profile_id SET NOT NULL;
|
||
|
|
|
||
|
|
-- graphic_designer_profiles
|
||
|
|
ALTER TABLE graphic_designer_profiles ADD COLUMN IF NOT EXISTS user_role_profile_id UUID;
|
||
|
|
UPDATE graphic_designer_profiles p SET user_role_profile_id = urp.id
|
||
|
|
FROM user_role_profiles urp
|
||
|
|
WHERE p.user_id = urp.user_id AND urp.role_key = 'graphic_designer';
|
||
|
|
ALTER TABLE graphic_designer_profiles ALTER COLUMN user_role_profile_id SET NOT NULL;
|
||
|
|
|
||
|
|
-- social_media_manager_profiles
|
||
|
|
ALTER TABLE social_media_manager_profiles ADD COLUMN IF NOT EXISTS user_role_profile_id UUID;
|
||
|
|
UPDATE social_media_manager_profiles p SET user_role_profile_id = urp.id
|
||
|
|
FROM user_role_profiles urp
|
||
|
|
WHERE p.user_id = urp.user_id AND urp.role_key = 'social_media_manager';
|
||
|
|
ALTER TABLE social_media_manager_profiles ALTER COLUMN user_role_profile_id SET NOT NULL;
|
||
|
|
|
||
|
|
-- fitness_trainer_profiles
|
||
|
|
ALTER TABLE fitness_trainer_profiles ADD COLUMN IF NOT EXISTS user_role_profile_id UUID;
|
||
|
|
UPDATE fitness_trainer_profiles p SET user_role_profile_id = urp.id
|
||
|
|
FROM user_role_profiles urp
|
||
|
|
WHERE p.user_id = urp.user_id AND urp.role_key = 'fitness_trainer';
|
||
|
|
ALTER TABLE fitness_trainer_profiles ALTER COLUMN user_role_profile_id SET NOT NULL;
|
||
|
|
|
||
|
|
-- catering_service_profiles
|
||
|
|
ALTER TABLE catering_service_profiles ADD COLUMN IF NOT EXISTS user_role_profile_id UUID;
|
||
|
|
UPDATE catering_service_profiles p SET user_role_profile_id = urp.id
|
||
|
|
FROM user_role_profiles urp
|
||
|
|
WHERE p.user_id = urp.user_id AND urp.role_key = 'catering_service';
|
||
|
|
ALTER TABLE catering_service_profiles ALTER COLUMN user_role_profile_id SET NOT NULL;
|
||
|
|
|
||
|
|
-- ugc_content_creator_profiles
|
||
|
|
ALTER TABLE ugc_content_creator_profiles ADD COLUMN IF NOT EXISTS user_role_profile_id UUID;
|
||
|
|
UPDATE ugc_content_creator_profiles p SET user_role_profile_id = urp.id
|
||
|
|
FROM user_role_profiles urp
|
||
|
|
WHERE p.user_id = urp.user_id AND urp.role_key = 'ugc_content_creator';
|
||
|
|
ALTER TABLE ugc_content_creator_profiles ALTER COLUMN user_role_profile_id SET NOT NULL;
|
||
|
|
|
||
|
|
-- Create indexes
|
||
|
|
CREATE INDEX IF NOT EXISTS idx_photographer_profiles_user_role ON photographer_profiles(user_role_profile_id);
|
||
|
|
CREATE INDEX IF NOT EXISTS idx_tutor_profiles_user_role ON tutor_profiles(user_role_profile_id);
|
||
|
|
CREATE INDEX IF NOT EXISTS idx_makeup_artist_profiles_user_role ON makeup_artist_profiles(user_role_profile_id);
|
||
|
|
CREATE INDEX IF NOT EXISTS idx_developer_profiles_user_role ON developer_profiles(user_role_profile_id);
|
||
|
|
CREATE INDEX IF NOT EXISTS idx_video_editor_profiles_user_role ON video_editor_profiles(user_role_profile_id);
|
||
|
|
CREATE INDEX IF NOT EXISTS idx_graphic_designer_profiles_user_role ON graphic_designer_profiles(user_role_profile_id);
|
||
|
|
CREATE INDEX IF NOT EXISTS idx_social_media_manager_profiles_user_role ON social_media_manager_profiles(user_role_profile_id);
|
||
|
|
CREATE INDEX IF NOT EXISTS idx_fitness_trainer_profiles_user_role ON fitness_trainer_profiles(user_role_profile_id);
|
||
|
|
CREATE INDEX IF NOT EXISTS idx_catering_service_profiles_user_role ON catering_service_profiles(user_role_profile_id);
|
||
|
|
CREATE INDEX IF NOT EXISTS idx_ugc_content_creator_profiles_user_role ON ugc_content_creator_profiles(user_role_profile_id);
|