2016-09-21 10 views
0

次のデータ構造を持つjsonファイルを使用しています。JSONオブジェクトを照会する方法

{"students":[ 
    {"Name":"Wale", "state":"Lagos", "age":20, "hobby":"dancing"}, 
    {"Name":"Ebere", "state":"Enugu", "age":18, "hobby":"eating"}, 
    {"Name":"Musa", "state":"Kano", "age":24, "hobby":"swimming"} 
]} 

私はイオン性のフレームワークでの作業と三つの変数からすべての生徒を選択する必要があるんだが... 状態、年齢や趣味を言います。これがSQL文の場合は、次のようになります。

$query = "Select * from students WHERE state = 'Enugu' AND age = '20' AND hobby = 'swimming'". 

私の質問は、どのようにjsonでこれを行うことができますか?

+0

は、どのような言語あなたはから 'json'データを照会するために使用していますか? – ode2k

+0

データはDBにjson形式で保存されますか? –

+0

@ ode2kさんの質問に対する回答ともう少し詳しく、投稿を更新してください。 jsonデータの照会に使用している言語は何ですか? –

答えて

0

独自の特殊言語をお探しの場合は、具体的には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" } 
] 
0

あなたは「クエリ」あなたのデータに.filter()を使用することができますセット。あなたが記載された特定のケースでは、次のようになります。

let data = {"students":[ 
 
    {"Name":"Wale", "state":"Lagos", "age":20, "hobby":"dancing"}, 
 
    {"Name":"Ebere", "state":"Enugu", "age":18, "hobby":"eating"}, 
 
    {"Name":"Musa", "state":"Kano", "age":24, "hobby":"swimming"} 
 
]}; 
 

 
// ES6!!! 
 
function filterStudents(students, name, age, state){ 
 
    return students.filter(student => student.state === state && student.age === age && student.Name === name) 
 
} 
 

 
console.log(filterStudents(data.students, 'Musa', 24, 'Kano'))

しかし、私が代わりに手動でフィルタケースを作成するためのライブラリで行くことにあなたをお勧めします。そのlibには、(私は創作者よ)あなたのケースに合うかどうかを確認してください:

https://github.com/DiegoZoracKy/data-query

関連する問題