2

我正在尝试在 Python 脚本中使用 OPENJSON 将一些基本的 JSON 导入 SQL 数据库。我最初尝试使用更复杂的 JSON 文件,但为了这篇文章而对其进行了简化。这是我所拥有的:

sql_statement = "declare @json nvarchar(max) = '{\"name\":\"James\"}'; SELECT * FROM OPENJSON(@json) WITH (name nvarchar(20))" 
cursor.execute(sql_statement)
cursor.commit()
connection.close()

我收到的错误:

pypyodbc.ProgrammingError: (u'42000', u"[42000] [Microsoft][ODBC SQL Server Driver][SQL Server]关键字'with'附近的语法不正确。如果此语句是公用表表达式,xmlnamespaces 子句或更改跟踪上下文子句,前一条语句必须以分号结束。”)

关于我为什么会看到此错误的任何想法?我成功地能够使用相同的 pypyodbc / 数据库配置执行其他 SQL 查询。

4

1 回答 1

8

问题可能是您的数据库运行在较旧的兼容级别,其中 OPEN JSON 不可用。

要查找数据库的兼容级别,请运行以下 SQL 语句:

SELECT compatibility_level  FROM sys.databases WHERE name = 'your_db_name';

如果结果为 120 或更低,则需要通过运行将兼容级别更新为 130:

ALTER DATABASE your_db_name SET COMPATIBILITY_LEVEL = 130;

注意:如果您的数据库实际上是 Azure SQL DB,您还应该检查版本,因为 OPEN JSON 不适用于 12.x 之前的版本

于 2016-07-29T09:15:21.880 回答