【发布时间】:2017-09-22 16:39:37
【问题描述】:
我知道 Parse.com 是一个 NoSql 数据库,并且 SQL 概念不应该应用于它,无论如何,除了理论之外,我敢打赌 Parse 中还有一种方法可以做一些类似于经典 SQL 连接的事情.
例如,假设我们的数据库中有 3 个表/类:人物、城市和国家,括号中包含示例值。
People:
-Name (Mario Rossi)
-Age (23)
-City (Bologna)
Cities:
-Name (Bologna)
-PostalCode (40100)
-Country (Italy)
Countries:
-Name (Italy)
-Continent (Europe)
鉴于此结构,假设我想知道 23 岁的马里奥·罗西 (Mario Rossi) 居住在哪个大陆。在经典的 SQL 方法中,这很容易实现,例如:
select People.Name,People.Age,Countries.Continent from People
JOIN Cities on People.City = Cities.name
JOIN Countries on City.Country = Countries.Name
Where People.Name = 'Mario Rossi'
生成的记录集将是“Mario Rossi, 23, Europe”。现在,如果我想用 Parse 做同样的事情,或者更好,如果我想用 Parse 获得 相同的结果,我的结构应该是什么样的?我应该使用指针吗?参考?我阅读了这些结构,但我不知道它们是否适用于这种情况以及如何使用它们。 我正在使用 Android 开发,但由于这是一个基本问题,我想我也可以接受/理解基于其他平台的答案。
谢谢!
根据 Fosco 的建议进行编辑:
public class CustomAdapter extends ParseQueryAdapter <ParseObject> implements OnItemClickListener{
public CustomAdapter(Context context) {
super(context, new ParseQueryAdapter.QueryFactory<ParseObject>() {
public ParseQuery<ParseObject> create() {
ParseQuery<ParseObject> query = ParseQuery.getQuery("People");
query.include("City");
query.include("City.Country");
query.whereEqualTo("Name","Mario Rossi");
return query;
}
});
}
@Override
public View getItemView(ParseObject parseobject, View v, ViewGroup parent) {
if (v==null){
v = View.inflate(getContext(), R.layout.row_ppl, null);
}
super.getItemView(parseobject, v, parent);
ParseObject city = parseobject.getParseObject("City");
ParseObject country = City.getParseObject("Country");
String continent = country.getString("Continent");
TextView nome = (TextView) v.findViewById(R.id.textView1);
nome.setText(parseobject.getString("Name"));
TextView cont = (TextView) v.findViewById(R.id.textView2);
cont.setText(continent);
return v;
}
@Override
public void onItemClick(AdapterView<?> arg0, View arg1, int arg2, long arg3) {
Log.d("rilevato ", "click");
}
}
【问题讨论】:
标签: android join parse-platform nosql