独自の特殊言語をお探しの場合は、具体的にはJSONデータモデル用に設計されたクエリ言語JSONiqをご覧ください。ここでWikipediaから取られた簡単な例です:
for $p in collection("persons")
where $p.age gt 20
let $home := $p.phoneNumber[][$$.type eq "home"].number
group by $area := substring-before($home, " ")
return
{
"area code" : $area,
"count" : count($p)
}
あなたはSQLに似た機能が句に参加したい場合は、以下のexampleを見てみましょう:
let $stores :=
[
{ "store number" : 1, "state" : "MA" },
{ "store number" : 2, "state" : "MA" },
{ "store number" : 3, "state" : "CA" },
{ "store number" : 4, "state" : "CA" }
]
let $sales := [
{ "product" : "broiler", "store number" : 1, "quantity" : 20 },
{ "product" : "toaster", "store number" : 2, "quantity" : 100 },
{ "product" : "toaster", "store number" : 2, "quantity" : 50 },
{ "product" : "toaster", "store number" : 3, "quantity" : 50 },
{ "product" : "blender", "store number" : 3, "quantity" : 100 },
{ "product" : "blender", "store number" : 3, "quantity" : 150 },
{ "product" : "socks", "store number" : 1, "quantity" : 500 },
{ "product" : "socks", "store number" : 2, "quantity" : 10 },
{ "product" : "shirt", "store number" : 3, "quantity" : 10 }
]
let $join :=
for $store in $stores[], $sale in $sales[]
where $store."store number" = $sale."store number"
return {
"nb" : $store."store number",
"state" : $store.state,
"sold" : $sale.product
}
return [$join]
-> [
{ "nb" : 1, "state" : "MA", "sold" : "broiler" },
{ "nb" : 1, "state" : "MA", "sold" : "socks" },
{ "nb" : 2, "state" : "MA", "sold" : "toaster" },
{ "nb" : 2, "state" : "MA", "sold" : "toaster" },
{ "nb" : 2, "state" : "MA", "sold" : "socks" },
{ "nb" : 3, "state" : "CA", "sold" : "toaster" },
{ "nb" : 3, "state" : "CA", "sold" : "blender" },
{ "nb" : 3, "state" : "CA", "sold" : "blender" },
{ "nb" : 3, "state" : "CA", "sold" : "shirt" }
]
は、どのような言語あなたはから 'json'データを照会するために使用していますか? – ode2k
データはDBにjson形式で保存されますか? –
@ ode2kさんの質問に対する回答ともう少し詳しく、投稿を更新してください。 jsonデータの照会に使用している言語は何ですか? –