1

以下のようなjsonオブジェクトがあります。

イーベイオブジェクト

    {
    __v: 0
    _id: "56e192f0aea7131c15513328"
    headquarters: "New York"
    name: "Ebay"
    productCategories: [{
        _id: "56e193beaea7131c1551332d"
        name: "Footwear"
        products: [{
            name: 'Shiela',
            price: 420,
            totalSales: [10, 20]
        }, {
            name: 'Parry',
            price: 350,
            totalSales: [50, 20]
        }]
        totalSales: 100
    }, {
        1: Object
        _id: "56e193beaea7131c1551332e"
        name: "Clothes"
        products: [{
            name: 'Kurta',
            price: 210,
            totalSales: [60, 80]
        }, {
            name: 'Sun Glass',
            price: 785,
            totalSales: [5, 25]
        }],
        totalSales: 170
    }]
}

アマゾンオブジェクト

{
        __v: 0
        _id: "56e192f0aea7131c15513328"
        headquarters: "New York"
        name: "Amazon"
        productCategories: [{
            _id: "56e193beaea7131c1551332d"
            name: "Footwear"
            products: [{
                name: 'Shiela',
                price: 280,
                totalSales: [10, 20]
            }, {
                name: 'Parry',
                price: 785,
                totalSales: [50, 20]
            }]
            totalSales: 100
        }, {
            1: Object
            _id: "56e193beaea7131c1551332e"
            name: "Clothes"
            products: [{
                name: 'Kurta',
                price: 150,
                totalSales: [60, 80]
            }, {
                name: 'Sun Glass',
                price: 485,
                totalSales: [5, 25]
            }],
            totalSales: 170
        }]
    }

両社に共通する製品カテゴリ内の各名前を選択したいと考えています。

次に、共通の製品カテゴリに共通する製品を選択したいと思います。

次に、比較のために(両社に)共通の製品の価格を取得したい

以下のクエリを実行できます

 alasql('SELECT products FROM ? AS CATEGORY1 JOIN ? AS CATEGORY2 USING [0]', [$scope.company1.productCategories, $scope.company2.productCategories], function(data) {
                    console.log("join query executed");
                    console.log(data);
                });

各製品カテゴリ内の製品を検索したい。次のようなクエリが必要です

alasql('SELECT products.name,products.price FROM ? as category1 join ? as category2 using products.name', [$scope.company1.productcategories,$scope.company2.productcategories], function(data) {
                    console.log("Query executed");
                    console.log(data);
                });

しかし、これはエラーになります。

正しい手順を教えてください。

よろしく、 サバリスリ

4

1 に答える 1

4

まず、ローカル メモリでのみ作業している場合は、非同期にする理由があります。したがって、最初の変更は使用する必要があります

var res = alasql('SELECT productCategories->0->name FROM ?',[$scope.selectedCompanies]);

あなたはとても近いです。基本的に、productCategories データのみに対してクエリを実行する必要があるため、実行する必要があります。

var res = alasql('SELECT name FROM ?',[$scope.selectedCompanies.productCategories]);

ボーナス情報: 何かに参加したい場合は、次のようなことができます

var res = alasql('SELECT p.name, d.stock FROM ? p JOIN ? d ON p.name = d.company',[$scope.selectedCompanies.productCategories, $scope.otherData]);
于 2016-03-14T23:10:47.027 に答える