Azure Synapse 中的 OPENJSON 排序规则导致排序规则冲突错误

Sli*_*icc 5 open-json azure-synapse

我有一个 OPENJSON 命令,它接受解析的 JSON 并将其 LEFT 连接到现有表上。

当我添加 LEFT JOIN 时,出现错误:

“Latin1_General_BIN2”和“SQL_Latin1_General_CP1_CI_AS”之间的排序规则冲突

该表的所有字符串列具有相同的排序规则: SQL_Latin1_General_CP1_CI_AS

我尝试在 LEFT JOIN 中添加 COLLATE DATABASE_DEFAULT,但没有任何改进。

我正在使用的查询大致如下:

DECLARE @json NVARCHAR(MAX) = '
{
    "ExampleJson": {
        "stuff": [
            {
                "_program_id": "hello",
                "work_date": "2021-03-23 00:00:00"
            }
        ]
    }
}';

SELECT *
FROM 
OPENJSON
(
    (
        @json
    ), '$.ExampleJson.stuff'
) 
 
WITH ( 
     [program_id] NVARCHAR(255) '$."program_id"'
     ,[work_date] DATETIME '$."work_date"'
) [json_data] 
  
 
LEFT JOIN 
    [existing_db_data]
    ON [existing_db_data].[program_id] = [json_data].[program_id] 
Run Code Online (Sandbox Code Playgroud)

wBo*_*Bob 6

我无法重现有趣的问题,但您应该能够通过在WITH子句中或连接之后放置正确的排序规则来解决,例如

WITH ( 
     [program_id] NVARCHAR(255) COLLATE SQL_Latin1_General_CP1_CI_AS '$."_program_id"' 
     ,[work_date] DATETIME '$."work_date"'
) [json_data] 
    LEFT JOIN [existing_db_data] d ON d.[program_id] = [json_data].[program_id] COLLATE SQL_Latin1_General_CP1_CI_AS
Run Code Online (Sandbox Code Playgroud)

两者之一就足够了,不需要两者都需要。

  • 我再次尝试使用 SQL_Latin1_General_CP1_CI_AS,但仍然没有运气。左表的 BIN2 排序规则很好,所以会继续,谢谢。 (3认同)