WITH login_names AS ( SELECT u.id user_id , u.instance_id , u.resource_owner , u.user_name , d.name domain_name , d.is_primary , p.must_be_domain , CASE WHEN p.must_be_domain THEN concat(u.user_name, '@', d.name) ELSE u.user_name END login_name FROM projections.login_names3_users u JOIN lateral ( SELECT p.must_be_domain FROM projections.login_names3_policies p WHERE u.instance_id = p.instance_id AND ( (p.is_default IS TRUE AND p.instance_id = $2) OR (p.instance_id = $2 AND p.resource_owner = u.resource_owner) ) ORDER BY is_default LIMIT 1 ) p ON TRUE JOIN projections.login_names3_domains d ON u.instance_id = d.instance_id AND u.resource_owner = d.resource_owner WHERE u.instance_id = $2 AND u.id = $1 ) SELECT u.id , u.creation_date , u.change_date , u.resource_owner , u.sequence , u.state , u.type , u.username , (SELECT array_agg(ln.login_name)::TEXT[] login_names FROM login_names ln GROUP BY ln.user_id, ln.instance_id) login_names , (SELECT ln.login_name login_names_lower FROM login_names ln WHERE ln.is_primary IS TRUE) preferred_login_name , h.user_id , h.first_name , h.last_name , h.nick_name , h.display_name , h.preferred_language , h.gender , h.avatar_key , n.user_id , n.last_email , n.verified_email , n.last_phone , n.verified_phone , n.password_set , count(*) OVER () FROM projections.users12 u LEFT JOIN projections.users12_humans h ON u.id = h.user_id AND u.instance_id = h.instance_id LEFT JOIN projections.users12_notifications n ON u.id = n.user_id AND u.instance_id = n.instance_id WHERE u.id = $1 AND u.instance_id = $2 LIMIT 1 ;