Merchant Center Query Language

Merchant Center クエリ言語(MCQL)は、SQL に似たクエリ言語です。マイページ MCQL と Merchant Reports API を使用して、 商品と競合している市場に関する パフォーマンスデータを取得できます

文法

MCQL の文法リファレンス(正規表現表記)は次のとおりです。

Query            -> SelectClause FromClause? WhereClause? OrderByClause? LimitClause?
SelectClause     -> SELECT FieldName (, FieldName)*
FromClause       -> FROM TableName
WhereClause      -> WHERE Condition (AND Condition)*
OrderByClause    -> ORDER BY Ordering (, Ordering)*
LimitClause      -> LIMIT PositiveInteger

Condition        -> FieldName Operator Value | FieldName BETWEEN Value AND Value
Operator         -> = | != | > | >= | < | <= | <> | IN | NOT IN |
                    CONTAINS ANY | CONTAINS ALL | CONTAINS NONE | DURING |
                    LIKE | NOT LIKE | REGEXP_MATCH | NOT REGEXP_MATCH
Value            -> Number | NumberList | String | StringList | Function
Ordering         -> FieldName (ASC | DESC)?

FieldName        -> [a-z] ([a-zA-Z0-9._])*
TableName        -> [A-Z] ([a-zA-Z_])*

StringList       -> ( String (, String)* )
NumberList       -> ( Number (, Number)* )

PositiveInteger  -> [1-9] ([0-9])*
Number           -> -? [0-9]+ (. [0-9] [0-9]*)?
String           -> (' Char* ') | (" Char* ")
Function         -> LAST_14_DAYS | LAST_30_DAYS | LAST_7_DAYS |
                    LAST_BUSINESS_WEEK | LAST_MONTH | LAST_WEEK_MON_SUN |
                    LAST_WEEK_SUN_SAT | THIS_MONTH | THIS_WEEK_MON_TODAY |
                    THIS_WEEK_SUN_TODAY | TODAY | YESTERDAY

次の記号を使用できます。

  • ? は省略可能な要素を示します。
  • * は 0 以上を意味します。+ は 1 つ以上を意味します。
  • (xxxxxx) はグループを示します。
  • [a-z0-9] は文字範囲を示します。
  • | は「または」を表します。
で確認できます。

大文字と小文字の区別

ほとんどの MCQL 演算子では大文字と小文字が区別されます。

演算子 大文字と小文字の区別
= または != 大文字と小文字を区別
(NOT)IN 大文字と小文字を区別
(NOT)LIKE 大文字と小文字を区別
次を含む(...) 大文字と小文字を区別
REGEXP_MATCH (省略可)両方

MCQL でクエリできる句は次のとおりです。

SELECT

SELECT 句は、取得するフィールドのカンマ区切りのリストを受け取ります。

使用しているビューから任意のフィールドを選択できます。では、生成 AI の 次のフィールドを選択できます。

1 つのリクエストで複数のフィールド タイプをクエリできます。次の例をご覧ください。

SELECT
  date,
  marketingMethod,
  impressions,
  clicks
FROM ProductPerformanceView
WHERE date BETWEEN '2020-08-01' AND '2020-08-31'

FROM

FROM 句には、リクエストでデータを取得するテーブルを指定します。Google Chat では FROM 句にフィールドを 1 つだけ指定する。FROM 句は、 すべてのクエリに適用されます。

WHERE

WHERE 句を使用して、リクエストのデータをフィルタリングします。WHERE 句 はパフォーマンスに必須です。 クエリをご覧ください。 すべてでフィルタできます segments フィールド さらに、 次の場合、metrics フィールド SELECT 句で指定します。

WHERE を使用して、指定したセグメントのインプレッションのみを返す例を次に示します。 期間(8 月):

SELECT offerId, impressions
FROM ProductPerformanceView
WHERE date BETWEEN '2020-08-01' AND '2020-08-31'

AND 演算子を使用すると、1 つのクエリで複数の条件でフィルタできます。 完全な条件間では AND を使用します(例: WHERE marketingMethod != "ADS" AND marketingMethod != "ORGANIC")。内の値の間で AND を使用することはできません。 単一の条件(例: WHERE marketingMethod != "ADS" AND "ORGANIC")。

商品ごとのクリック数を返す例を次に示します。 マーケティング メソッド「ADS」で、次の月に 100 回を超えるクリック 8 月:

SELECT offerId, clicks
FROM ProductPerformanceView
WHERE clicks > 100
  AND marketingMethod = 'ADS'
  AND date BETWEEN '2020-08-01' AND '2020-08-31'

WHERE 句は OR をサポートしていません。演算子では大文字と小文字が区別されます。1 つの 演算子の完全なリストについては、文法をご覧ください。

ORDER BY(省略可)

ORDER BY 句を使用すると、指定した順序で結果を取得できます。

順序は fieldName で指定し、次に ASC または DESC で指定します。並べ替えられるのは クエリの SELECT 句で指定されたフィールド。ORDER BY のデフォルト 指定しない場合は ASC になります。

次のクエリは、返された行をクリック数の多い順に並べます。 昇順:

SELECT offerId, clicks
FROM ProductPerformanceView
WHERE date BETWEEN '2020-08-01' AND '2020-08-31'
ORDER BY clicks DESC

ORDER BY 句では、カンマで区切って複数のフィールドを指定できます。 選択します。

たとえば、次のクエリの結果は、 offerId、次にインプレッション数の降順、降順、 クリック数で並べ替えます

SELECT offerId, impressions, clicks
FROM ProductPerformanceView
WHERE date BETWEEN '2020-08-01' AND '2020-08-31'
ORDER BY
  offerId,
  impressions DESC,
  clicks DESC

LIMIT

LIMIT 句を使用すると、返される結果の数を指定できます。

次の例では、もっと多くの行を使用できる場合でも、50 件の結果のみが返されます。

SELECT offerId, impressions
FROM ProductPerformanceView
WHERE date BETWEEN '2020-08-01' AND '2020-08-31'
ORDER BY impressions DESC
LIMIT 50

pageSize フィールドを使用して、長い結果リストを処理します。

期間

MCQL では、カスタム期間または相対的な期間を指定できます。使用するには、 WHERE 句で、すべてのパフォーマンスに対して date の範囲を指定する クエリをご覧ください。

カスタム

ISO 8601(YYYY-MM-DD)の日付は次の形式で指定できます。

  • date BETWEEN '2021-01-01' AND '2021-01-31'
  • date >= '2021-01-01' AND date <= '2021-01-31'

日付文字列は一重引用符(')または二重引用符で定義できます。 (")。

相対

LAST_30_DAYSTHIS_MONTH などの相対的な期間を指定できます。 BETWEENAND の代わりに DURING を使用すると、次のようになります。

WHERE date DURING LAST_30_DAYS

使用可能な相対的な期間の一覧については、文法をご覧ください。