PostgreSQL SELECT 减去数组(NOT IN)
SELECT DISTINCT ON
(u.user_uuid, u.firstname)
u.user_uuid,
u.firstname,
u.preposition,
u.lastname,
array_to_string_ex(ARRAY(SELECT email FROM emails WHERE user_uuid =
u.user_uuid)) as emails,
array_to_string_ex(ARRAY(SELECT mobilenumber FROM mobilenumbers WHERE
user_uuid = u.user_uuid)) as
mobilenumbers,
array_to_string_ex(ARRAY(SELECT c.name FROM targetgroupusers AS tgu
LEFT JOIN membercategories as mc ON
mc.targetgroup_uuid =
tgu.targetgroup_uuid LEFT JOIN
categories AS c ON mc.category_uuid =
c.category_uuid WHERE tgu.user_uuid =
u.user_uuid)) as categories,
array_to_string_ex(ARRAY(SELECT color FROM membercategories WHERE
targetgroup_uuid IN(SELECT
targetgroup_uuid FROM targetgroupusers
WHERE user_uuid = u.user_uuid))) as
colors FROM
membercategories AS mc LEFT JOIN
targetgroups AS tg ON
tg.targetgroup_uuid = mc.targetgroup_uuid LEFT JOIN
targetgroupusers AS tgu ON
tgu.targetgroup_uuid = tg.targetgroup_uuid LEFT JOIN
users AS u ON
u.user_uuid = tgu.user_uuid LEFT JOIN
emails AS e ON
e.user_uuid = u.user_uuid LEFT JOIN
mobilenumbers AS m ON
m.user_uuid = u.user_uuid WHERE mc.targetgroup_uuid IS NOT NULL AND
u.user_uuid !=
ANY('{5b1f5ae5-b033-4b02-8bd0-3a9f7f2ccf19}'::UUID[])
AND isdeleted = false AND
mc.company_uuid = '5edcecd0-0534-11e0-81e0-0800200c9a66'
AND (u.firstname ~* 'dir') OR (u.preposition ~* 'dir') OR
(u.lastname ~* 'dir') OR (e.email ~*
'dir') OR (m.mobilenumber ~* 'dir')
ORDER BY
u.firstname ASC
OFFSET 0
LIMIT 10
为什么我仍然得到 user_uuid = 5b1f5ae5-b033-4b02-8bd0-3a9f7f2ccf19 的结果?!?
SELECT DISTINCT ON
(u.user_uuid, u.firstname)
u.user_uuid,
u.firstname,
u.preposition,
u.lastname,
array_to_string_ex(ARRAY(SELECT email FROM emails WHERE user_uuid =
u.user_uuid)) as emails,
array_to_string_ex(ARRAY(SELECT mobilenumber FROM mobilenumbers WHERE
user_uuid = u.user_uuid)) as
mobilenumbers,
array_to_string_ex(ARRAY(SELECT c.name FROM targetgroupusers AS tgu
LEFT JOIN membercategories as mc ON
mc.targetgroup_uuid =
tgu.targetgroup_uuid LEFT JOIN
categories AS c ON mc.category_uuid =
c.category_uuid WHERE tgu.user_uuid =
u.user_uuid)) as categories,
array_to_string_ex(ARRAY(SELECT color FROM membercategories WHERE
targetgroup_uuid IN(SELECT
targetgroup_uuid FROM targetgroupusers
WHERE user_uuid = u.user_uuid))) as
colors FROM
membercategories AS mc LEFT JOIN
targetgroups AS tg ON
tg.targetgroup_uuid = mc.targetgroup_uuid LEFT JOIN
targetgroupusers AS tgu ON
tgu.targetgroup_uuid = tg.targetgroup_uuid LEFT JOIN
users AS u ON
u.user_uuid = tgu.user_uuid LEFT JOIN
emails AS e ON
e.user_uuid = u.user_uuid LEFT JOIN
mobilenumbers AS m ON
m.user_uuid = u.user_uuid WHERE mc.targetgroup_uuid IS NOT NULL AND
u.user_uuid !=
ANY('{5b1f5ae5-b033-4b02-8bd0-3a9f7f2ccf19}'::UUID[])
AND isdeleted = false AND
mc.company_uuid = '5edcecd0-0534-11e0-81e0-0800200c9a66'
AND (u.firstname ~* 'dir') OR (u.preposition ~* 'dir') OR
(u.lastname ~* 'dir') OR (e.email ~*
'dir') OR (m.mobilenumber ~* 'dir')
ORDER BY
u.firstname ASC
OFFSET 0
LIMIT 10
How comes i still get the result with user_uuid = 5b1f5ae5-b033-4b02-8bd0-3a9f7f2ccf19 ?!?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
因为
AND
的优先级高于OR
。将
OR
子句括在括号中:Because
AND
has higher precedence thanOR
.Enclose your
OR
clauses into parentheses: