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 พิจารณาตัวพิมพ์เล็กและใหญ่
CONTAINS (...) พิจารณาตัวพิมพ์เล็กและใหญ่
REGEXP_MATCH ไม่บังคับทั้ง 2 อย่าง

ข้อ

ต่อไปนี้คือข้อความที่คุณค้นหาได้ด้วย MCQL

SELECT

SELECTClause จะใช้รายการฟิลด์ที่คั่นด้วยคอมมาเพื่อดึงข้อมูล

คุณเลือกฟิลด์ใดก็ได้จากมุมมองที่ใช้อยู่ ตัวอย่างฟิลด์ที่คุณเลือกได้มีดังนี้

คุณสามารถค้นหาฟิลด์หลายประเภทในคำขอเดียวได้ เช่น

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 (ไม่บังคับ)

ORDER BY clause ช่วยให้คุณดึงผลลัพธ์ตามลำดับที่ระบุได้

ระบุลำดับโดยใช้ 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 clause ช่วยให้คุณระบุจำนวนผลลัพธ์ที่จะแสดงได้

ตัวอย่างต่อไปนี้จะแสดงผลลัพธ์เพียง 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

ดูไวยากรณ์เพื่อดูรายการช่วงวันที่แบบสัมพัทธ์ทั้งหมดที่พร้อมใช้งาน