ใน Google Ads API จะใช้มาสก์ของฟิลด์เพื่อระบุรายการฟิลด์ ที่คำขอ API ควรจะอัปเดต ระบบจะไม่สนใจฟิลด์ที่ไม่ได้ระบุในฟิลด์ มาสก์ แม้ว่าจะส่งไปยังเซิร์ฟเวอร์ก็ตาม
คลาส FieldMaskUtil
วิธีที่แนะนำในการสร้างมาสก์ฟิลด์คือการใช้คลาส FieldMaskUtil
ในตัว ซึ่งช่วยให้คุณสร้างมาสก์ฟิลด์จากออบเจ็กต์ที่แก้ไขแล้วได้
แทนที่จะสร้างตั้งแต่ต้น
ตัวอย่างการอัปเดตแคมเปญที่ใช้วิธี FieldMasks.AllSetFieldsOf
เพื่อสร้างมาสก์ฟิลด์ที่แจกแจงฟิลด์ที่ตั้งค่าทั้งหมด
จากนั้นคุณจะส่งฟิลด์มาสก์ที่สร้างขึ้นไปยัง
การเรียกใช้การอัปเดตได้โดยตรง
// Update campaign by setting its status to paused, and "Search network" to false.
Campaign campaignToUpdate = new Campaign()
{
ResourceName = ResourceNames.Campaign(customerId, campaignId),
Status = CampaignStatus.Paused,
NetworkSettings = new NetworkSettings()
{
TargetSearchNetwork = false
}
};
// Create the operation.
CampaignOperation operation = new CampaignOperation()
{
Update = campaignToUpdate,
UpdateMask = FieldMasks.AllSetFieldsOf(campaignToUpdate)
};
// Update the campaign.
MutateCampaignsResponse response = campaignService.MutateCampaigns(
customerId.ToString(), new CampaignOperation[] { operation });
ในบางครั้ง คุณอาจต้องทำงานกับออบเจ็กต์ที่มีอยู่และอัปเดตฟิลด์บางรายการ
ในกรณีดังกล่าว คุณจะต้องแก้ไขโค้ดเพื่อใช้เมธอด FieldMasks.FromChanges
แทน วิธีนี้จะสร้างมาสก์ฟิลด์ที่แสดง
ความแตกต่างระหว่างออบเจ็กต์ 2 รายการ
Campaign existingCampaign;
// Obtain existingCampaign from elsewhere.
...
// Create a new campaign based off the existing campaign for update.
Campaign campaignToUpdate = new Campaign(existingCampaign);
// Update campaign by setting its status to paused, and "Search network" to
// false.
campaignToUpdate.Status = CampaignStatus.Paused;
campaignToUpdate.NetworkSettings = new NetworkSettings()
{
TargetSearchNetwork = false
}
// Create the operation.
CampaignOperation operation = new CampaignOperation()
{
Update = campaignToUpdate,
UpdateMask = FieldMasks.FromChanges(existingCampaign, campaignToUpdate)
};
วิธีจัดการข้อผิดพลาด FieldMaskError.FIELD_HAS_SUBFIELDS
ในบางกรณีที่พบได้น้อย คุณอาจต้องตั้งค่าช่องโดยไม่ต้องอัปเดตฟิลด์ย่อยของประเภทนั้น ลองดูตัวอย่างต่อไปนี้
// Creates a campaign with the proper resource name and an empty
// MaximizeConversions field.
Campaign campaign = new Campaign()
{
ResourceName = ResourceNames.Campaign(customerId, campaignId),
MaximizeConversions = new MaximizeConversions()
};
CampaignOperation operation = new CampaignOperation()
{
Update = campaign,
UpdateMask = FieldMasks.AllSetFieldsOf(campaign)
};
MutateCampaignsResponse response = campaignService.MutateCampaigns(
customerId.ToString(), new CampaignOperation[] { operation });
การเรียก API นี้จะล้มเหลวและแสดงFieldMaskError.FIELD_HAS_SUBFIELDS
เนื่องจาก MaximizeConversions
มีฟิลด์ย่อย 3 รายการ เซิร์ฟเวอร์ Google Ads API จึงคาดหวังว่า
จะเห็นมาสก์ของฟิลด์สำหรับฟิลด์เหล่านั้นในคำขอ อย่างไรก็ตาม FieldMaskUtil
ไม่สามารถสร้างมาสก์ฟิลด์
ได้อย่างถูกต้องในกรณีนี้ เนื่องจากคำขอไม่ได้ตั้งค่าฟิลด์เหล่านี้
ในกรณีดังกล่าว คุณจะแก้ไขฟิลด์มาสก์ด้วยตนเองได้ดังนี้
// Creates a Campaign object with the proper resource name.
Campaign campaign = new Campaign()
{
ResourceName = ResourceNames.Campaign(customerId, campaignId),
};
FieldMask fieldMask = FieldMasks.AllSetFieldsOf(campaign);
// Only include 'maximize_conversions.target_cpa_micros' in the field mask
// as it is the only mutable subfield on MaximizeConversions when used as a
// standard bidding strategy.
//
// Learn more about standard and portfolio bidding strategies here:
// https://developers.google.com/google-ads/api/docs/campaigns/bidding/assign-strategies
fieldMask.Paths.AddRange(new string[] {
"maximize_conversions.target_cpa_micros",
});
// Creates an operation to update the campaign with the specified fields.
CampaignOperation operation = new CampaignOperation()
{
Update = campaign,
UpdateMask = fieldMask
};
วิธีล้างช่อง
Google Ads API รองรับการล้างค่าของฟิลด์บางรายการ หากต้องการล้างช่อง คุณต้องตั้งค่าฟิลด์มาสก์สำหรับช่องนั้นด้วยตนเอง การตั้งค่าช่องเป็นค่าเริ่มต้น (เช่น 0 สำหรับช่อง int64) จะไม่ล้างช่อง
ตัวอย่างโค้ดต่อไปนี้แสดงวิธีล้างฟิลด์ target_cpa_micros
ของ
MaximizeConversions
กลยุทธ์การเสนอราคา
รหัสที่ถูกต้อง
โค้ดต่อไปนี้จะล้างช่อง target_cpa_micros
เนื่องจากเรา
ตั้งค่า maximize_conversions.target_cpa_micros
ในมาสก์ฟิลด์และ
ไม่ได้ตั้งค่าฟิลด์ campaign.MaximizeConversions.TargetCpaMicros
// Creates a Campaign object with the proper resource name.
Campaign campaign = new Campaign()
{
ResourceName = ResourceNames.Campaign(customerId, campaignId),
};
// Constructs a field mask from the existing campaign and adds the
// 'maximize_conversions.target_cpa_micros' field to the field mask, which will
// clear this field from the bidding strategy without impacting any other fields
// on the bidding strategy.
FieldMask fieldMask = FieldMasks.AllSetFieldsOf(campaign);
fieldMask.Paths.AddRange(new string[] {
"maximize_conversions.target_cpa_micros",
});
// Creates an operation to update the campaign with the specified field.
CampaignOperation operation = new CampaignOperation()
{
Update = campaign,
UpdateMask = fieldMask
};
รหัสไม่ถูกต้อง
โค้ดต่อไปนี้จะไม่ล้างฟิลด์ target_cpa_micros
เนื่องจากเรา
ตั้งค่าฟิลด์นี้เป็น 0 ทั้ง FieldMaskUtils
และเซิร์ฟเวอร์ Google Ads API
จะไม่สนใจค่านี้ นอกจากนี้ คุณอาจไม่ได้รับข้อผิดพลาดในกรณีนี้ด้วย เนื่องจากเซิร์ฟเวอร์ไม่สนใจค่าดังกล่าว
// Creates a campaign with the proper resource name and a MaximizeConversions
// object. Attempt to clear the target_cpa_micros field by setting it to 0.
Campaign campaign = new Campaign()
{
ResourceName = ResourceNames.Campaign(customerId, campaignId),
MaximizeConversions = new MaximizeConversions()
{
TargetCpaMicros = 0
}
};
// Constructs an operation, using the FieldMasks' AllSetFieldsOf utility to
// derive the update mask. However, the field mask will NOT include
// 'maximize_conversions.target_cpa_micros'.
CampaignOperation operation = new CampaignOperation()
{
Update = campaign,
UpdateMask = FieldMasks.AllSetFieldsOf(campaign)
};
// Sends the operation in a mutate request that will succeed but will NOT update
// the 'target_cpa_micros' field because 'maximize_conversions.target_cpa_micros'
// was not included in the field mask.
MutateCampaignsResponse response = campaignService.MutateCampaigns(
customerId.ToString(), new CampaignOperation[] { operation });