gpt4 book ai didi

android - Parse.com 相当于 SQL 连接

转载 作者:塔克拉玛干 更新时间:2023-11-02 21:10:42 24 4
gpt4 key购买 nike

我知道 Parse.com 是一个 NoSql 数据库,SQL 概念不应该应用于它,无论如何,除了理论,我敢打赌在 Parse 中有一种方法可以做类似经典 SQL 连接的事情.

例如,假设我们的数据库中有 3 个表/类:People、Cities 和 Countries,示例值在括号中。

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 岁,欧洲”。现在,如果我想用 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");

}

}

最佳答案

如果您在 Parse 上创建 Country 和 City 作为类,并使用指针,您可以很容易地做到这一点。

Cities 包含一个指向 Countries 的指针,列名为“country”

People 包含指向 Cities 的指针,列名为“city”

var query = new Parse.Query("People");
query.include('city');
query.include('city.country');
query.equalTo('Name', 'Mario Rossi');
query.first().then(function(person) {
console.log(person);
}, function(err) {

});

拉取人员记录时,您将拥有完整的城市和国家记录。

编辑以添加 Android 示例:

ParseQuery<ParseObject> query = ParseQuery.getQuery("People");
query.include("city");
query.include("city.country");
query.whereEqualTo("Name", "Mario Rossi");
query.getFirstInBackground(new GetCallback<ParseObject>() {
public void done(ParseObject person, ParseException e) {
if (e == null) {
ParseObject city = object.get("city");
ParseObject country = city.get("country");
String continent = country.get("continent");
} else {
Log.d("person", "Error: " + e.getMessage());
}
}
});

关于android - Parse.com 相当于 SQL 连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24239626/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com