Uprość odpowiedź Couchdb JSON
Przechowuję dane lokalizacji w Couchdb i szukam sposobu, aby uzyskać tablicę tylko wartości, zamiast key: value dla każdego rekordu. Na przykład:
Aktualna odpowiedź
{"total rows": 250, "offset": 0, "rows":[
{"id": "ec5de6de2cf7bcac9a2a2a76de5738e4", "key": "user1", "value": {"city": "San Francisco", "address":"1001 Bayhill Dr"},
{"id": "ec5de6de2cf7bcac9a2a2a76de573ae4","key": "user1", "value": {"city": "Palo Alto", "address":"583 Waverley St"}
... (etc).
]}
I only really need:
[{"city": "San Francisco", "address":"1001 Bayhill Dr"},
{"city": "Palo Alto", "address":"583 Waverley St"},
...]
Powodem tego wszystkiego jest zminimalizowanie przepustowości, jaką zużywa odpowiedź JSON. Nie mogę znaleźć sposobu na przekształcenie widoku w prostą tablicę. Jakieś sugestie?
Dzięki. 14
1 answers
Możesz użyć funkcji _show i _list , przyjmują one dokument lub widok (odpowiednio) i mogą odesłać przekształconą odpowiedź w dowolnym formacie. (w tym przypadku JSON)
Aktualizacja: przeprowadziłem prosty test z danymi, które podałeś na moim własnym CouchDB. Oto funkcja listy, którą napisałem. Dostosuj go do swoich potrzeb. :)
function (head, req) {
// specify that we're providing a JSON response
provides('json', function() {
// create an array for our result set
var results = [];
while (row = getRow()) {
results.push({
city: row.value.city,
address: row.value.address
});
}
// make sure to stringify the results :)
send(JSON.stringify(results));
});
}
19
Author: Dominic Barnes,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2011-02-10 05:39:32
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2011-02-10 05:39:32