لغة استعلامات 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
يمكنك استخدام الرموز التالية:
- يشير الرمز
?
إلى عنصر اختياري. - يشير الرمز
*
إلى صفر أو أكثر، ويشير الرمز+
إلى واحد أو أكثر. - يشير الرمز
(xxxxxx)
إلى مجموعة. - يشير الرمز
[a-z0-9]
إلى نطاقات الأحرف. - يشير الرمز
|
إلى "أو".
الحساسية لحالة الأحرف
معظم عوامل تشغيل MCQL حسّاسة لحالة الأحرف:
عوامل التشغيل | الحساسية لحالة الأحرف |
---|---|
= أو != | حساس لحالة الأحرف |
(ليس) في | حساس لحالة الأحرف |
(ليس) مثل | حساس لحالة الأحرف |
CONTAINS (...) | حساس لحالة الأحرف |
REGEXP_MATCH | كلاهما اختياري |
العبارات
في ما يلي الجمل التي يمكنك البحث عنها باستخدام لغة MCQL:
SELECT
تأخذ عبارة SELECT
قائمة بحقول مفصولة بفواصل لاستردادها.
يمكنك اختيار أيّ حقل من طريقة العرض التي تستخدمها. في ما يلي بعض الأمثلة على الحقول التي يمكنك اختيارها:
يمكنك طلب البحث عن أنواع حقول متعددة في طلب واحد. وفي ما يلي مثال لذلك:
SELECT
date,
marketing_method,
impressions,
clicks
FROM product_performance_view
WHERE date BETWEEN '2023-08-01' AND '2023-08-31'
FROM
تحدد العبارة 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 (اختياري)
تتيح لك عبارة 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'
يمكنك تحديد سلاسل التواريخ باستخدام علامات اقتباس مفردة ('
) أو علامات اقتباس مضاعفة
("
).
قريب
يمكنك تحديد نطاق زمني نسبي، مثل LAST_30_DAYS
أو THIS_MONTH
،
باستخدام DURING
بدلاً من BETWEEN
وAND
:
WHERE date DURING LAST_30_DAYS
اطّلِع على قواعد اللغة للحصول على القائمة الكاملة لنطاقات التواريخ النسبية المتاحة.