ChangeStatus proporciona un medio para hacer un seguimiento de qué recursos cambiaron en una cuenta durante un período determinado. Si un recurso tuvo varios cambios durante el período determinado, solo se muestra el cambio más reciente. Luego, puedes determinar si necesitas sincronizar los valores de tu base de datos local con los que cambiaron durante el período.
Por ejemplo, si durante un período determinado agregas y, luego, actualizas una campaña determinada, solo se muestra el estado de cambio de la operación UPDATE y no de la operación ADD. Si mueves el final del período a un momento anterior a la actualización, verás la operación ADD.
Si quieres obtener los resultados completos campo por campo con una vista detallada, consulta
ChangeEvent.
Comprende el alcance de los cambios informados
Cuando ChangeStatus indica un cambio en un recurso, como una
CAMPAIGN, significa que se modificó el recurso en sí
o uno de sus recursos subordinados (un grupo de anuncios, un anuncio o un criterio dentro
de esa campaña).
El recurso ChangeStatus tiene como objetivo proporcionar una descripción general amplia de qué partes
de tu cuenta tuvieron actividad. Si se produce un cambio en un recurso secundario, es posible que se muestre el ID del recurso superior para garantizar que no se pierda ninguna modificación. Esto es especialmente cierto para los tipos de recursos que no se enumeran de forma explícita en
la ChangeStatusResourceType enumeración.
Por ejemplo, si bien una modificación en un modificador de ofertas del grupo de anuncios marca el
AdGroupBidModifier tipo de recurso, un cambio
en una entidad secundaria menos detallada o más reciente podría marcar la
Campaign o AdGroup
superior en su lugar.
Para obtener detalles a nivel de campo sobre qué cambió exactamente, puedes usar el
ChangeEvent recurso, que proporciona una vista más
detallada de las creaciones y actualizaciones.
Tipos de estado de cambio
Se hace un seguimiento de los siguientes tipos de recursos. Ten en cuenta que los IDs de los tipos de recursos son diferentes de los índices de valores de enumeración
de ChangeStatusResourceType.
| Tipo de recurso | Valor | ID del tipo de recurso |
|---|---|---|
| Entidades principales | ||
| Grupo de anuncios | AD_GROUP | 2 |
| Anuncio del grupo de anuncios | AD_GROUP_AD | 3 |
| Modificador de ofertas del grupo de anuncios | AD_GROUP_BID_MODIFIER | 11 |
| Criterio del grupo de anuncios | AD_GROUP_CRITERION | 4 |
| Feed del grupo de anuncios | AD_GROUP_FEED | 12 |
| Grupo de recursos | ASSET_BUNDLE | 19 |
| Campaña | CAMPAIGN | 5 |
| Presupuesto de la campaña | CAMPAIGN_BUDGET | 7 |
| Criterio de campaña | CAMPAIGN_CRITERION | 6 |
| Feeds | ||
| Feed de campaña | CAMPAIGN_FEED | 9 |
| Feed | FEED | 8 |
| Elemento del feed | FEED_ITEM | 10 |
| Conjuntos compartidos | ||
| Conjunto compartido | SHARED_SET | 17 |
| Conjunto compartido de campaña | CAMPAIGN_SHARED_SET | 18 |
| Recursos | ||
| Recurso | ASSET | 13 |
| Conjunto de recursos | ASSET_SET | 25 |
| Elemento del cliente | CUSTOMER_ASSET | 14 |
| Recurso de la campaña | CAMPAIGN_ASSET | 15 |
| Conjunto de recursos de campaña | CAMPAIGN_ASSET_SET | 26 |
| Recurso del grupo de anuncios | AD_GROUP_ASSET | 16 |
Cómo determinar el tipo de recurso por ID
La API de Google Ads puede mostrar filas con un valor de tipo de recurso UNKNOWN para versiones anteriores de la API, lo que significa que el tipo es compatible con una versión futura de la API de Google Ads, pero no era totalmente compatible en el momento en que se lanzó tu versión actual. Cuando esto sucede, puedes determinar el tipo de recurso de la fila analizando el resource_name que se muestra.
El formato del nombre del recurso es el siguiente:
customers/{customer_id}/changeStatus/{timestamp}-{resource_type_id}-{additional_ids}
Podría haber uno o más IDs adicionales, separados por el carácter -, pero el que es relevante es resource_type_id, el segundo ID después de la barra final. En la tabla anterior, se enumeran todos los IDs de los tipos de recursos.
Cómo recuperar cambios
La lista de cambios se puede filtrar por fecha y por tipo de recurso. La
operación en un recurso determinado es una de
ADDED, CHANGED o REMOVED.
Puedes recuperar la lista de todos los cambios para todos los tipos de recursos. El
resource_type que se muestra es el campo que cambió. También se propagan todos los campos superiores. Por ejemplo, si cambió el ad_group_criterion, también se propaga el campo
ad_group.
Un cambio puede tardar hasta 3 minutos en reflejarse en los resultados del estado de cambio.
La consulta debe filtrar por una fecha dentro de los últimos 90 días y, de manera opcional, una hora, y debe incluir una cláusula LIMIT establecida en un máximo de 10,000 resultados.
Java
private void runExample(GoogleAdsClient googleAdsClient, long customerId) { String query = "SELECT change_status.resource_name, " + "change_status.last_change_date_time, " + "change_status.resource_status, " + "change_status.resource_type, " + "change_status.ad_group, " + "change_status.ad_group_ad, " + "change_status.ad_group_bid_modifier, " + "change_status.ad_group_criterion, " + "change_status.campaign, " + "change_status.campaign_criterion, " + "FROM change_status " + "WHERE change_status.last_change_date_time DURING LAST_14_DAYS " + "ORDER BY change_status.last_change_date_time " + "LIMIT 10000"; try (GoogleAdsServiceClient client = googleAdsClient.getLatestVersion().createGoogleAdsServiceClient()) { SearchPagedResponse response = client.search(String.valueOf(customerId), query); for (GoogleAdsRow row : response.iterateAll()) { Optional<String> resourceNameOfChangedEntity = getResourceNameForResourceType(row.getChangeStatus()); System.out.printf( "On '%s', change status '%s' shows a resource type of '%s' " + "with resource name '%s' was '%s'.%n", row.getChangeStatus().getLastChangeDateTime(), row.getChangeStatus().getResourceName(), row.getChangeStatus().getResourceType().name(), resourceNameOfChangedEntity.orElse(""), row.getChangeStatus().getResourceStatus().name()); } } }
C#
public void Run(GoogleAdsClient client, long customerId) { // Get the GoogleAdsService. GoogleAdsServiceClient googleAdsService = client.GetService( Services.V23.GoogleAdsService); string searchQuery = @" SELECT change_status.resource_name, change_status.last_change_date_time, change_status.resource_type, change_status.campaign, change_status.ad_group, change_status.resource_status, change_status.ad_group_ad, change_status.ad_group_criterion, change_status.campaign_criterion FROM change_status WHERE change_status.last_change_date_time DURING LAST_14_DAYS ORDER BY change_status.last_change_date_time LIMIT 10000"; // Create a request that will retrieve all changes. SearchGoogleAdsRequest request = new SearchGoogleAdsRequest() { Query = searchQuery, CustomerId = customerId.ToString() }; try { // Issue the search request. PagedEnumerable<SearchGoogleAdsResponse, GoogleAdsRow> searchPagedResponse = googleAdsService.Search(request); // Iterate over all rows in all pages and prints the requested field values for the // campaign in each row. foreach (GoogleAdsRow googleAdsRow in searchPagedResponse) { Console.WriteLine("Last change: {0}, Resource type: {1}, " + "Resource name: {2}, Resource status: {3}, Specific resource name: {4}", googleAdsRow.ChangeStatus.LastChangeDateTime, googleAdsRow.ChangeStatus.ResourceType, googleAdsRow.ChangeStatus.ResourceName, googleAdsRow.ChangeStatus.ResourceStatus, SpecificResourceName(googleAdsRow.ChangeStatus.ResourceType, googleAdsRow)); } } catch (GoogleAdsException e) { Console.WriteLine("Failure:"); Console.WriteLine($"Message: {e.Message}"); Console.WriteLine($"Failure: {e.Failure}"); Console.WriteLine($"Request ID: {e.RequestId}"); throw; } } /// <summary> /// Return the name of the most specific resource that changed. /// </summary> /// <param name="resourceType">Type of the resource.</param> /// <param name="row">Each returned row contains all possible changed fields</param> /// <returns>The resource name of the changed field based on the resource type. /// The changed field's parent is also populated, but is not used.</returns> private string SpecificResourceName(ChangeStatusResourceType resourceType, GoogleAdsRow row) { string resourceName; switch (resourceType) { case ChangeStatusResourceType.AdGroup: resourceName = row.ChangeStatus.AdGroup; break; case ChangeStatusResourceType.AdGroupAd: resourceName = row.ChangeStatus.AdGroupAd; break; case ChangeStatusResourceType.AdGroupCriterion: resourceName = row.ChangeStatus.AdGroupCriterion; break; case ChangeStatusResourceType.Campaign: resourceName = row.ChangeStatus.Campaign; break; case ChangeStatusResourceType.CampaignCriterion: resourceName = row.ChangeStatus.CampaignCriterion; break; case ChangeStatusResourceType.Unknown: case ChangeStatusResourceType.Unspecified: default: resourceName = ""; break; } return resourceName; }
PHP
public static function runExample(GoogleAdsClient $googleAdsClient, int $customerId) { $googleAdsServiceClient = $googleAdsClient->getGoogleAdsServiceClient(); // Creates a query to find information about changed resources in your account. $query = 'SELECT change_status.resource_name, ' . 'change_status.last_change_date_time, ' . 'change_status.resource_status, ' . 'change_status.resource_type, ' . 'change_status.ad_group, ' . 'change_status.ad_group_ad, ' . 'change_status.ad_group_bid_modifier, ' . 'change_status.ad_group_criterion, ' . 'change_status.ad_group_feed, ' . 'change_status.campaign, ' . 'change_status.campaign_criterion, ' . 'change_status.campaign_feed, ' . 'change_status.feed, ' . 'change_status.feed_item ' . 'FROM change_status ' . 'WHERE change_status.last_change_date_time DURING LAST_14_DAYS ' . 'ORDER BY change_status.last_change_date_time ' . 'LIMIT 10000'; // Issues a search request. $response = $googleAdsServiceClient->search( SearchGoogleAdsRequest::build($customerId, $query) ); // Iterates over all rows in all pages and prints the requested field values for // the change status in each row. foreach ($response->iterateAllElements() as $googleAdsRow) { /** @var GoogleAdsRow $googleAdsRow */ printf( "On %s, change status '%s' shows resource '%s' with type '%s' and status '%s'.%s", $googleAdsRow->getChangeStatus()->getLastChangeDateTime(), $googleAdsRow->getChangeStatus()->getResourceName(), self::getResourceNameForResourceType($googleAdsRow->getChangeStatus()), ChangeStatusResourceType::name( $googleAdsRow->getChangeStatus()->getResourceType() ), ChangeStatusOperation::name($googleAdsRow->getChangeStatus()->getResourceStatus()), PHP_EOL ); } } /** * Gets the resource name for the resource type of the change status object. * * Each returned row contains all possible changed resources, only one of which is populated * with the name of the changed resource. This function returns the resource name of the * changed resource based on the resource type. * * @param ChangeStatus $changeStatus the change status object for getting changed resource * @return string the name of the resource that changed */ private static function getResourceNameForResourceType( ChangeStatus $changeStatus ) { $resourceType = $changeStatus->getResourceType(); $resourceName = ''; // Default value for UNSPECIFIED or UNKNOWN resource type. switch ($resourceType) { case ChangeStatusResourceType::AD_GROUP: $resourceName = $changeStatus->getAdGroup(); break; case ChangeStatusResourceType::AD_GROUP_AD: $resourceName = $changeStatus->getAdGroupAd(); break; case ChangeStatusResourceType::AD_GROUP_BID_MODIFIER: $resourceName = $changeStatus->getAdGroupBidModifier(); break; case ChangeStatusResourceType::AD_GROUP_CRITERION: $resourceName = $changeStatus->getAdGroupCriterion(); break; case ChangeStatusResourceType::AD_GROUP_FEED: $resourceName = $changeStatus->getAdGroupFeed(); break; case ChangeStatusResourceType::CAMPAIGN: $resourceName = $changeStatus->getCampaign(); break; case ChangeStatusResourceType::CAMPAIGN_CRITERION: $resourceName = $changeStatus->getCampaignCriterion(); break; case ChangeStatusResourceType::CAMPAIGN_FEED: $resourceName = $changeStatus->getCampaignFeed(); break; case ChangeStatusResourceType::FEED: $resourceName = $changeStatus->getFeed(); break; case ChangeStatusResourceType::FEED_ITEM: $resourceName = $changeStatus->getFeedItem(); break; } return $resourceName; }
Python
def main(client: GoogleAdsClient, customer_id: str) -> None: ads_service: GoogleAdsServiceClient = client.get_service("GoogleAdsService") # Construct a query to find information about changed resources in your # account. query = """ SELECT change_status.resource_name, change_status.last_change_date_time, change_status.resource_type, change_status.campaign, change_status.ad_group, change_status.resource_status, change_status.ad_group_ad, change_status.ad_group_criterion, change_status.campaign_criterion FROM change_status WHERE change_status.last_change_date_time DURING LAST_14_DAYS ORDER BY change_status.last_change_date_time LIMIT 10000""" search_request: SearchGoogleAdsRequest = client.get_type( "SearchGoogleAdsRequest" ) search_request.customer_id = customer_id search_request.query = query response: SearchPagedResponse = ads_service.search(request=search_request) row: GoogleAdsRow for row in response: cs: ChangeStatus = row.change_status resource_type: str = cs.resource_type.name resource_name: str if resource_type == "AD_GROUP": resource_name = cs.ad_group elif resource_type == "AD_GROUP_AD": resource_name = cs.ad_group_ad elif resource_type == "AD_GROUP_CRITERION": resource_name = cs.ad_group_criterion elif resource_type == "CAMPAIGN": resource_name = cs.campaign elif resource_type == "CAMPAIGN_CRITERION": resource_name = cs.campaign_criterion else: resource_name = "UNKNOWN" resource_status: str = cs.resource_status.name print( f"On '{cs.last_change_date_time}', change status " f"'{cs.resource_name}' shows that a resource type of " f"'{resource_type}' with resource name '{resource_name}' was " f"{resource_status}" )
Ruby
def get_change_summary(customer_id) # GoogleAdsClient will read a config file from # ENV['HOME']/google_ads_config.rb when called without parameters client = Google::Ads::GoogleAds::GoogleAdsClient.new # Construct a query to find information about changed resources in your # account. query = <<~QUERY SELECT change_status.resource_name, change_status.last_change_date_time, change_status.resource_type, change_status.campaign, change_status.ad_group, change_status.resource_status, change_status.ad_group_ad, change_status.ad_group_criterion, change_status.campaign_criterion FROM change_status WHERE change_status.last_change_date_time DURING LAST_14_DAYS ORDER BY change_status.last_change_date_time LIMIT 10000 QUERY # Execute the query. response = client.service.google_ads.search( customer_id: customer_id, query: query, ) # Process the results. response.each do |row| cs = row.change_status resource_name = case cs.resource_type when :AD_GROUP cs.ad_group when :AD_GROUP_AD cs.ad_group_ad when :AD_GROUP_CRITERION cs.ad_group_criterion when :CAMPAIGN cs.campaign when :CAMPAIGN_CRITERION cs.campaign_criterion else "UNKNOWN" end puts "On #{cs.last_change_date_time}, change status #{cs.resource_name} " \ "shows a resource type of #{cs.resource_type} " \ "with resource name #{resource_name} was #{cs.resource_status}." end end
Perl
sub get_change_summary { my ($api_client, $customer_id) = @_; # Construct a search query to find information about changed resources in your # account. my $search_query = "SELECT change_status.resource_name, change_status.last_change_date_time, " . "change_status.resource_status, " . "change_status.resource_type, " . "change_status.ad_group, " . "change_status.ad_group_ad, " . "change_status.ad_group_bid_modifier, " . "change_status.ad_group_criterion, " . "change_status.ad_group_feed, " . "change_status.campaign, " . "change_status.campaign_criterion, " . "change_status.campaign_feed, " . "change_status.feed, " . "change_status.feed_item " . "FROM change_status " . "WHERE change_status.last_change_date_time DURING LAST_14_DAYS " . "ORDER BY change_status.last_change_date_time " . "LIMIT 10000"; # Create a search Google Ads request that will retrieve all change statuses using # pages of the specified page size. my $search_request = Google::Ads::GoogleAds::V24::Services::GoogleAdsService::SearchGoogleAdsRequest ->new({ customerId => $customer_id, query => $search_query }); # Get the GoogleAdsService. my $google_ads_service = $api_client->GoogleAdsService(); my $iterator = Google::Ads::GoogleAds::Utils::SearchGoogleAdsIterator->new({ service => $google_ads_service, request => $search_request }); # Iterate over all rows in all pages and print the requested field values for # the change status in each row. while ($iterator->has_next) { my $google_ads_row = $iterator->next; my $change_status = $google_ads_row->{changeStatus}; printf "On %s, change status '%s' shows a resource type of '%s' " . "with resource name '%s' was '%s'.\n", $change_status->{lastChangeDateTime}, $change_status->{resourceName}, $change_status->{resourceType}, __get_resource_name_for_resource_type($change_status), $change_status->{resourceStatus}; } return 1; } # This method returns the resource name of the changed field based on the # resource type. The changed field's parent is also populated but is not used. sub __get_resource_name_for_resource_type { my $change_status = shift; my $resource_type = $change_status->{resourceType}; if ($resource_type eq AD_GROUP) { return $change_status->{adGroup}; } elsif ($resource_type eq AD_GROUP_AD) { return $change_status->{adGroupAd}; } elsif ($resource_type eq AD_GROUP_BID_MODIFIER) { return $change_status->{adGroupBidModifier}; } elsif ($resource_type eq AD_GROUP_CRITERION) { return $change_status->{adGroupCriterion}; } elsif ($resource_type eq AD_GROUP_FEED) { return $change_status->{adGroupFeed}; } elsif ($resource_type eq CAMPAIGN) { return $change_status->{campaign}; } elsif ($resource_type eq CAMPAIGN_CRITERION) { return $change_status->{campaignCriterion}; } elsif ($resource_type eq CAMPAIGN_FEED) { return $change_status->{campaignFeed}; } elsif ($resource_type eq FEED) { return $change_status->{feed}; } elsif ($resource_type eq FEED_ITEM) { return $change_status->{feedItem}; } else { return ""; } }
curl
Cómo sincronizar de forma local
Una vez que se recupera el resource_name preciso, se debe realizar una nueva consulta con este nombre de recurso para obtener todos los valores actuales del recurso. No se hace un seguimiento del estado de cambio para los valores modificados de un recurso específico, solo de qué recursos cambiaron. Determinar la diferencia entre los valores anteriores y actuales es responsabilidad del programa que realiza la llamada.
Cambiar hora
El last_change_date_time
campo indica cuándo se produjo el cambio más reciente en un recurso. Por lo tanto, la actualización de los datos almacenados en caché de forma local se puede comparar con el valor de este campo para determinar si los datos locales no están actualizados.
Ten en cuenta que este campo también se puede filtrar, lo que significa que se puede usar en la WHERE
cláusula de una consulta del lenguaje de consultas de Google Ads (GAQL), lo que te permite consultar los
cambios en los recursos que se produjeron antes o después de una hora determinada.
Por ejemplo, para encontrar todos los cambios que se produjeron para un tipo de recurso determinado durante la última semana, se puede usar la siguiente cláusula de predicado GAQL:
WHERE change_status.last_change_date_time DURING LAST_7_DAYS