繁体   English   中英

GROUP_CONCAT到STUFF的转换返回错误

[英]GROUP_CONCAT to STUFF conversion returning error

我正在尝试将此查询从mysQL转换为SQL Server。

SELECT TOP 50 m.*,
(SELECT GROUP_CONCAT(lookup_id) as ids FROM data_lookups_ref WHERE ref_id = m.member_id and lu_type = 'prof_accr_status') as prof_accr_status_ids
FROM members m;

根据其他信息,我已将其转换为

SELECT TOP 50 m.*,
id_list = STUFF((
          SELECT ',' + lu.lookup_id
          FROM data_lookups_ref lu
          WHERE lu.ref_id = m.member_id
          FOR XML PATH(''), TYPE).value('.', 'NVARCHAR(MAX)'), 1, 1, '')
FROM members m;

但是,我收到以下错误。

ERROR: SELECT failed because the following SET options have incorrect
settings: 'ARITHABORT'. Verify that SET options are
correct for use with indexed views and/or indexes on computed
columns and/or filtered indexes and/or query notifications
and/or XML data type methods and/or spatial index operations.
Error
Code: 1934

关于做错了什么的任何建议,将不胜感激。

您能尝试一下吗?

SELECT TOP 50 m.*,
STUFF((
      SELECT TOP 50 ',' + convert(varchar(10), lu.lookup_id)
      FROM data_lookups_ref lu
      WHERE lu.ref_id = m.member_id
      FOR XML PATH('')),1,1,'') AS ids
FROM members m

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM