Parse.com等同于SQL连接

时间:2014-06-16 08:41:17

标签: android join parse-platform nosql

我知道Parse.com是一个NoSql数据库,SQL概念不应该应用于它,无论如何,除了理论之外,我敢打赌有一种方法可以解决像经典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岁,欧洲"。现在,如果我想用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");

    }

}

1 个答案:

答案 0 :(得分:3)

如果您在Parse上创建Country和City作为类,并使用指针,则可以非常轻松地完成此操作。

城市包含指向国家/地区,列名称&#39;国家&#39;

的指针

人们包含指向城市的指针,列名称&#39;城市&#39;

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) {

});

你将拥有完整的城市&amp;拉动人事记录时的国家记录。

编辑以添加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());
        }
    }
});