PDF (US Ltr) - 2.3Mb
PDF (A4) - 2.3Mb
MySQL Shell 提供了多种 JSON 格式选项来打印结果集
-
json
或json/pretty
这两个选项都会生成美观的 JSON。
-
ndjson
或json/raw
这两个选项都会生成以换行符分隔的原始 JSON。
-
json/array
此选项会生成包装在 JSON 数组中的原始 JSON。
您可以通过在启动 MySQL Shell 时使用 --result-format=
命令行选项,或设置 MySQL Shell 配置选项 value
resultFormat
来选择这些输出格式。
在批处理模式下,为了帮助将 MySQL Shell 与外部工具集成,您可以使用 --json
选项来控制从命令行启动 MySQL Shell 时所有输出的 JSON 包装。启用 JSON 包装后,MySQL Shell 将生成美观的 JSON(默认)或原始 JSON,并且会忽略 resultFormat
MySQL Shell 配置选项的值。有关说明,请参阅 第 5.7.5 节,“JSON 包装”。
示例 5.4 美观的 JSON 格式输出(json
或 json/pretty
))
Press CTRL+C to copyMySQL localhost:33060+ ssl world_x JS > shell.options.set('resultFormat','json') MySQL localhost:33060+ ssl world_x JS > session.sql("select * from city where countrycode='AUT'") { "ID": 1523, "Name": "Wien", "CountryCode": "AUT", "District": "Wien", "Info": { "Population": 1608144 } } { "ID": 1524, "Name": "Graz", "CountryCode": "AUT", "District": "Steiermark", "Info": { "Population": 240967 } } { "ID": 1525, "Name": "Linz", "CountryCode": "AUT", "District": "North Austria", "Info": { "Population": 188022 } } { "ID": 1526, "Name": "Salzburg", "CountryCode": "AUT", "District": "Salzburg", "Info": { "Population": 144247 } } { "ID": 1527, "Name": "Innsbruck", "CountryCode": "AUT", "District": "Tiroli", "Info": { "Population": 111752 } } { "ID": 1528, "Name": "Klagenfurt", "CountryCode": "AUT", "District": "Kärnten", "Info": { "Population": 91141 } } 6 rows in set (0.0031 sec)
示例 5.5 带有换行符分隔符的原始 JSON 格式输出(ndjson
或 json/raw
))
Press CTRL+C to copyMySQL localhost:33060+ ssl world_x JS > shell.options.set('resultFormat','ndjson') MySQL localhost:33060+ ssl world_x JS > session.sql("select * from city where countrycode='AUT'") {"ID":1523,"Name":"Wien","CountryCode":"AUT","District":"Wien","Info":{"Population":1608144}} {"ID":1524,"Name":"Graz","CountryCode":"AUT","District":"Steiermark","Info":{"Population":240967}} {"ID":1525,"Name":"Linz","CountryCode":"AUT","District":"North Austria","Info":{"Population":188022}} {"ID":1526,"Name":"Salzburg","CountryCode":"AUT","District":"Salzburg","Info":{"Population":144247}} {"ID":1527,"Name":"Innsbruck","CountryCode":"AUT","District":"Tiroli","Info":{"Population":111752}} {"ID":1528,"Name":"Klagenfurt","CountryCode":"AUT","District":"Kärnten","Info":{"Population":91141}} 6 rows in set (0.0032 sec)
示例 5.6 包装在 JSON 数组中的原始 JSON 格式输出(json/array
))
Press CTRL+C to copyMySQL localhost:33060+ ssl world_x JS > shell.options.set('resultFormat','json/array') MySQL localhost:33060+ ssl world_x JS > session.sql("select * from city where countrycode='AUT'") [ {"ID":1523,"Name":"Wien","CountryCode":"AUT","District":"Wien","Info":{"Population":1608144}}, {"ID":1524,"Name":"Graz","CountryCode":"AUT","District":"Steiermark","Info":{"Population":240967}}, {"ID":1525,"Name":"Linz","CountryCode":"AUT","District":"North Austria","Info":{"Population":188022}}, {"ID":1526,"Name":"Salzburg","CountryCode":"AUT","District":"Salzburg","Info":{"Population":144247}}, {"ID":1527,"Name":"Innsbruck","CountryCode":"AUT","District":"Tiroli","Info":{"Population":111752}}, {"ID":1528,"Name":"Klagenfurt","CountryCode":"AUT","District":"Kärnten","Info":{"Population":91141}} ] 6 rows in set (0.0032 sec)