Merchant Center Query Language (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
می توانید از نمادهای زیر استفاده کنید:
-
?
یک عنصر اختیاری را نشان می دهد. -
*
به معنای صفر یا بیشتر است.+
به معنای یک یا چند است. -
(xxxxxx)
یک گروه بندی را نشان می دهد. -
[a-z0-9]
نشان دهنده محدوده کاراکترها است. -
|
مخفف "یا" است.
حساسیت به حروف کوچک و بزرگ
اکثر اپراتورهای MCQL به حروف کوچک و بزرگ حساس هستند:
اپراتورها | حساسیت به حروف کوچک |
---|---|
= یا != | حساس به حروف کوچک و بزرگ |
(نه) در | حساس به حروف کوچک و بزرگ |
(نه) لایک | حساس به حروف کوچک و بزرگ |
حاوی (...) | حساس به حروف کوچک و بزرگ |
REGEXP_MATCH | اختیاری هر دو |
بندها
در اینجا بندهایی وجود دارد که می توانید با MCQL پرس و جو کنید:
انتخاب کنید
عبارت SELECT
فهرستی از فیلدهای جدا شده با کاما را برای بازیابی می گیرد.
شما می توانید هر فیلدی را از نمای مورد استفاده خود انتخاب کنید. در اینجا چند نمونه از فیلدهایی وجود دارد که می توانید انتخاب کنید:
شما می توانید انواع فیلدهای مختلف را در یک درخواست جستجو کنید. در اینجا یک مثال است:
SELECT
date,
marketing_method,
impressions,
clicks
FROM product_performance_view
WHERE date BETWEEN '2023-08-01' AND '2023-08-31'
از
عبارت FROM
جدولی را برای واکشی داده ها در درخواست مشخص می کند. شما فقط می توانید یک فیلد را در عبارت FROM
مشخص کنید. عبارت FROM
برای همه پرس و جوها لازم است.
کجا
از عبارت WHERE
برای فیلتر کردن داده های درخواست خود استفاده کنید. بند WHERE
برای پرس و جوهای عملکرد مورد نیاز است. میتوانید بر اساس تمام قسمتها ، و اگر آنها را در بند SELECT
مشخص کنید، با فیلدهای معیارهای اضافی فیلتر کنید.
در اینجا مثالی آورده شده است که WHERE
برای برگرداندن نمایشها از یک دوره زمانی مشخص (ماه آگوست) استفاده میکند:
SELECT offer_id, impressions
FROM product_performance_view
WHERE date BETWEEN '2023-08-01' AND '2023-08-31'
با عملگر AND
می توانید با چند شرط در یک کوئری فیلتر کنید. از AND
بین شرایط کامل استفاده کنید، برای مثال: WHERE marketing_method != "ADS" AND marketing_method != "ORGANIC"
. شما نمی توانید از AND
بین مقادیر در یک شرط استفاده کنید، به عنوان مثال: WHERE marketing_method != "ADS" AND "ORGANIC"
.
در اینجا مثالی آورده شده است که تعداد کلیکهای هر پیشنهاد را که بیش از 100 کلیک وجود دارد، برای روش بازاریابی ADS
در طول ماه آگوست برمیگرداند:
SELECT offer_id, clicks
FROM product_performance_view
WHERE clicks > 100
AND marketing_method = 'ADS'
AND date BETWEEN '2023-08-01' AND '2023-08-31'
عبارت WHERE
از OR
پشتیبانی نمی کند. اپراتورها به حروف کوچک و بزرگ حساس هستند. برای فهرست کامل عملگرها، گرامر را ببینید.
سفارش بر اساس (اختیاری)
عبارت ORDER BY
به شما امکان می دهد نتایج را در یک ترتیب مشخص بازیابی کنید.
ترتیب را با یک field_name
و سپس ASC
یا DESC
مشخص کنید. شما فقط می توانید بر اساس فیلدهای مشخص شده در بند SELECT
درخواست خود سفارش دهید. اگر مشخص نکنید، ORDER BY
روی ASC
پیشفرض است.
پرس و جو زیر ردیف های برگشتی را بر اساس تعداد کلیک، از بالاترین به کمترین مرتب می کند:
SELECT offer_id, clicks
FROM product_performance_view
WHERE date BETWEEN '2023-08-01' AND '2023-08-31'
ORDER BY clicks DESC
شما می توانید چندین فیلد را در عبارت ORDER BY
با استفاده از یک لیست جدا شده با کاما مشخص کنید.
به عنوان مثال، نتایج جستجوی زیر به ترتیب صعودی بر اساس offer_id
، سپس به ترتیب نزولی بر اساس تعداد نمایشها و سپس به ترتیب نزولی بر اساس تعداد کلیکها مرتب میشوند:
SELECT offer_id, impressions, clicks
FROM product_performance_view
WHERE date BETWEEN '2020-08-01' AND '2020-08-31'
ORDER BY
offer_id,
impressions DESC,
clicks DESC
LIMIT
بند LIMIT
به شما امکان می دهد تعداد نتایجی را که باید برگردانید مشخص کنید.
در اینجا یک مثال است که تنها 50 نتیجه را برمی گرداند، حتی اگر ردیف های بیشتری در دسترس باشد.
SELECT offer_id, impressions
FROM product_performance_view
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'
می توانید رشته های تاریخ را با گیومه های تکی ( '
) یا دو گیومه ( "
) تعریف کنید.
نسبی
با استفاده از DURING
به جای BETWEEN
و AND
می توانید یک محدوده تاریخ نسبی مانند LAST_30_DAYS
یا THIS_MONTH
را مشخص کنید:
WHERE date DURING LAST_30_DAYS
برای فهرست کامل محدودههای تاریخ نسبی موجود ، به دستور زبان مراجعه کنید.