【问题标题】:Parse.com equivalent to SQL joinsParse.com 相当于 SQL 连接
【发布时间】: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


    【解决方案1】:

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

    Cities 包含一个指向 Country 的指针,列名 '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());
            }
        }
    });
    

    【讨论】:

    • 我会在几天后尝试并通知您。谢谢你现在
    • 特别是console.log(person);行所在的地方,你可以使用var continent = person.get('city').get('country').get('name');
    • 现在正在尝试。 equalTo 方法在 Android 中不存在。那么,我将如何访问 Continent 字符串?谢谢。
    • 我在孵出之前数过我的鸡,遗憾的是,这段代码出现了空指针异常: ParseObject city = parseobject.getParseObject("Name"); ParseObject country = city.getParseObject("Country"); String 大陆 = country.getString("大陆");
    • Name 是一个指向城市的指针,做一些调试 parseobject 填充了名字和年龄,而 Name 保持为空(对不起命名约定)
    猜你喜欢
    • 1970-01-01
    • 2011-03-30
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-03-03
    • 2014-06-05
    • 1970-01-01
    相关资源
    最近更新 更多