Fuente de datos de eventos de facturación
Esta fuente de datos proporciona información sobre eventos de facturación, incluidos facturación y desembolsos.
Por ejemplo, puede utilizar esta fuente de datos para saber cuándo y qué se factura a un comprador. También puede utilizar las consultas de SQL de ejemplo para analizar los datos de esta fuente de datos.
Esta fuente de datos contiene información asociada con eventos de facturación para los que es el vendedor registrado. Para los acuerdos realizados a través de socios de canal, esta fuente de datos contiene información sobre eventos de facturación entre el fabricante y el vendedor de registro.
La fuente de datos de eventos de facturación se actualiza cada 24 horas, por lo que los nuevos datos están disponibles diariamente.
Los datos de eventos de facturación son inmutables.
En la tabla siguiente se incluyen los nombres y descripciones de las columnas de la fuente de datos.
Nombre de la columna | Descripción |
---|---|
billing_event_id | Un identificador de un evento de facturación. Este ID es único en el entorno del vendedor. |
from_account_id |
La cuenta que inició el evento de facturación. Si Se puede usar para unirse a la fuente de datos de |
to_account_id | La cuenta que recibe el importe de la transacción del producto. Esta es una clave externa para la fuente de datos de la cuenta. Se puede usar para unirse a la fuente de datos de |
end_user_account_id | La cuenta que utiliza el producto. Esta cuenta puede ser diferente de las cuentas de comprador y pagador. Se puede usar para unirse a la fuente de datos |
product_id | El identificador del producto. Esta es una clave externa para la fuente de datos del producto. Se puede usar para unirse a la fuente de datos de |
acción |
El tipo de acción de este evento. Los valores posibles son los siguientes:
|
transaction_type |
El tipo de transacción. Para ver ejemplos, consulte Escenarios de impuestos. Los valores posibles son los siguientes:
|
parent_billing_event_id |
Cuando el valor de Cuando el valor de
Si el valor de
Si el valor de |
disbursement_billing_event_id |
El desembolso relacionado cuando el valor de
En todos los demás escenarios, este valor es nulo. |
importe | El importe del evento de facturación. |
divisa | El código de moneda ISO 639. |
balance_impacting | Si el importe se tiene en cuenta al calcular los desembolsos del vendedor. Un valor de 0 indica que el importe se muestra con fines informativos y no tiene ningún efecto sobre el saldo. Un valor de 1 indica que este importe se tiene en cuenta al determinar los desembolsos del vendedor. |
invoice_date | La fecha en que se creó la factura. |
payment_due_date |
Cuando el valor de |
usage_period_start_date | La fecha de inicio del periodo del registro. |
usage_period_end_date | La fecha de finalización del periodo del registro. |
invoice_id |
El ID de la factura de AWS. |
billing_address_id | La referencia de la dirección de facturación del pagador en la fuente de datos de la dirección. Se puede usar para unirse a la fuente de datos de |
transaction_reference_id |
Un identificador que le permite hacer referencias cruzadas a datos de los siguientes informes: |
bank_trace_id |
En el caso de las transacciones de desembolso ( |
broker_id |
Un identificador de la entidad comercial que facilitó la transacción. Los valores posibles son los siguientes:
|
buyer_transaction_reference_id |
Un identificador que agrupa todos los registros relacionados de la fuente de facturación mediante |
Escenarios de impuestos
El modelo fiscal vigente del país y del estado del comprador y el vendedor determina cómo se recaudan y remiten los impuestos. A continuación, se muestran los escenarios posibles:
-
AWS recauda y remite los impuestos. En estos casos,
transaction_type
esAWS_TAX_SHARE
. -
AWS recauda los impuestos, que se asignan al vendedor y este los remite a las autoridades fiscales. En estos casos,
transaction_type
esSELLER_TAX_SHARE
. -
AWS no recauda los impuestos. El vendedor debe calcular los impuestos y remitirlos a las autoridades fiscales. En estos casos, AWS Marketplace no realiza cálculos de impuestos ni recibe información fiscal. El vendedor paga los impuestos de la parte de ingresos.
Ejemplos de fuente de datos de eventos de facturación
En esta sección se muestran ejemplos del periodo de datos del evento de facturación en el momento de la facturación y un mes después. Tenga en cuenta lo siguiente para todas las tablas de esta sección:
-
En las fuentes de datos, los valores de
billing_event_id
son cadenas alfanuméricas de 40 caracteres. Se muestran aquí como cadenas de dos caracteres para facilitar la lectura. -
En la fuente de datos, esta información se presenta en una sola tabla. Para facilitar la lectura, los datos se muestran aquí en varias tablas y no aparecen todas las columnas.
Para los ejemplos de esta sección, suponga lo siguiente:
-
Arnav es el comprador.
-
El ID de su cuenta es
737399998888
. -
Está ubicado en Francia, que está sujeto a las leyes de facilitadores del mercado. Para obtener más información, consulte Ayuda fiscal de Amazon Web Service
. -
Compró
prod-o4grxfafcxxxx
y se le facturaron 120,60 dólares por el uso mensual de ese producto. -
Pagó la factura dentro del mes.
-
-
Jane es la fabricante.
-
El ID de su cuenta es
111122223333
.
-
-
Paulo es el vendedor de registro.
-
El ID de su cuenta es
777788889999
. -
Vive en Kansas, que no está sujeta a las leyes de facilitadores del mercado.
-
Fuente de datos de eventos de facturación para el vendedor de registro
Como vendedor de registro, Paulo factura al comprador, Arnav.
En las siguientes tablas se muestra la información relevante en la fuente de datos de Paulo cuando factura a Arnav.
billing_event_id | from_account_id | to_account_id | end_user_account_id | product_id | action | transaction_type |
---|---|---|---|---|---|---|
I0 | 737399998888 | 777788889999 | 737399998888 | prod-o4grxfafcxxxx | FACTURADO | SELLER_REV_SHARE |
I1 | 737399998888 | AWS | 737399998888 | prod-o4grxfafcxxxx | FACTURADO | AWS_TAX_SHARE |
I2 | 777788889999 | 111122223333 | 737399998888 | prod-o4grxfafcxxxx | FACTURADO | SELLER_REV_SHARE |
I3 | 777788889999 | AWS | 737399998888 | prod-o4grxfafcxxxx | FACTURADO | AWS_REV_SHARE |
parent_billing_event_id | disbursement_billing_event_id | amount | divisa | invoice_date | invoice_id |
---|---|---|---|---|---|
100 | USD | 2018-12-31T00:00:00Z | 781216640 | ||
20.6 | USD | 2018-12-31T00:00:00Z | 781216640 | ||
-80 | USD | 2018-12-31T00:04:07Z | 788576665 | ||
-0.2 | USD | 2018-12-31T00:04:07Z | 788576665 |
En las siguientes tablas se muestra la información relevante en la fuente de datos de Paulo al final del mes, después de que Arnav pague la factura.
billing_event_id | from_account_id | to_account_id | end_user_account_id | product_id | action | transaction_type |
---|---|---|---|---|---|---|
I10 | 737399998888 | 777788889999 | 737399998888 | DESEMBOLSADO | SELLER_REV_SHARE | |
I12 | 777788889999 | 111122223333 | 737399998888 | DESEMBOLSADO | SELLER_REV_SHARE | |
I13 | 777788889999 | AWS | 737399998888 | prod-o4grxfafcxxxx | DESEMBOLSADO | AWS_REV_SHARE |
I14 | AWS | 777788889999 | DESEMBOLSADO | ABONO |
parent_billing_event_id | disbursement_billing_event_id | amount | divisa | invoice_date | invoice_id |
---|---|---|---|---|---|
I0 | I14 | -100 | USD | 2018-12-31T00:00:00Z | 781216640 |
I2 | I14 | 80 | USD | 2018-12-31T00:04:07Z | 788576665 |
I3 | I14 | 0.2 | USD | 2018-12-31T00:04:07Z | 788576665 |
19.8 | USD |
Fuente de datos de eventos de facturación para el fabricante
En las siguientes tablas se muestra la información relevante en la fuente de datos de Jane cuando Paulo factura a Arnav.
billing_event_id | from_account_id | to_account_id | end_user_account_id | product_id | action | transaction_type |
---|---|---|---|---|---|---|
I5 | 777788889999 | 111122223333 | prod-o4grxfafcxxxx | FACTURADO | SELLER_REV_SHARE | |
I6 | 777788889999 | 111122223333 | prod-o4grxfafcxxxx | FACTURADO | SELLER_TAX_SHARE | |
I7 | 111122223333 | AWS | prod-o4grxfafcxxxx | FACTURADO | AWS_REV_SHARE |
parent_billing_event_id | disbursement_billing_event_id | amount | divisa | invoice_date | invoice_id |
---|---|---|---|---|---|
73.5 | 2018-12-31T00:04:07Z | 788576665 | |||
6.5 | 2018-12-31T00:04:07Z | 788576665 | |||
-7.35 | 2018-12-31T00:04:07Z | 788576665 |
En las siguientes tablas se muestra la información relevante en la fuente de datos de Jane al final del mes, después de pagar la factura.
billing_event_id | from_account_id | to_account_id | end_user_account_id | product_id | action | transaction_type |
---|---|---|---|---|---|---|
I30 | 777788889999 | 111122223333 | prod-o4grxfafcxxxx | DESEMBOLSADO | SELLER_REV_SHARE | |
I31 | 777788889999 | 111122223333 | prod-o4grxfafcxxxx | DESEMBOLSADO | SELLER_TAX_SHARE | |
I32 | 111122223333 | AWS | prod-o4grxfafcxxxx | DESEMBOLSADO | AWS_REV_SHARE | |
I33 | AWS | 111122223333 | DESEMBOLSADO | ABONO |
parent_billing_event_id | disbursement_billing_event_id | amount | divisa | invoice_date | invoice_id |
---|---|---|---|---|---|
I5 | I33 | -73.5 | USD | ||
I6 | I33 | -6.5 | USD | ||
I7 | I33 | 7.35 | USD | ||
72.65 | USD |
Consultas de ejemplo
Como se describe en Recopilación y análisis de datos con fuentes de datos, puede utilizar Athena para ejecutar consultas sobre los datos que se recopilan y almacenan como fuentes de datos en el bucket de Amazon S3 administrado. En esta sección se proporcionan algunos ejemplos de formas comunes de hacerlo. Todos los ejemplos suponen que se utiliza una moneda única.
Ejemplo 1: Importe facturado, incluidos los impuestos
Para saber cuánto se facturó a los compradores, incluidos los impuestos, puede ejecutar una consulta como la que se muestra en el siguiente ejemplo.
SELECT sum(amount) FROM billing_event WHERE action = 'INVOICED' AND ( (transaction_type in ('SELLER_REV_SHARE', 'SELLER_TAX_SHARE') -- to discard SELLER_REV_SHARE from Manufacturer to Channel Partner, aka cost of goods AND to_account_id='
seller-account-id
' ) OR transaction_type= 'AWS_TAX_SHARE' );
Ejemplo 2: Importe facturado a los compradores en nombre del vendedor
Para saber cuántos compradores se facturaron en nombre de un vendedor, puede ejecutar una consulta como la que se muestra en el siguiente ejemplo.
SELECT sum(amount) FROM billing_event WHERE action = 'INVOICED' AND transaction_type in ('SELLER_REV_SHARE', 'SELLER_TAX_SHARE') AND to_account_id='
seller-account-id
' ;
Ejemplo 3: El importe que AWS puede recaudar en nombre del vendedor
Para saber cuánto puede recaudar AWS en nombre de un vendedor, menos los reembolsos, créditos y cuentas perdonadas, puede ejecutar una consulta como se muestra en el siguiente ejemplo:
SELECT sum(amount) FROM billing_event WHERE -- what is invoiced on behalf of SELLER, incl. refunds/ credits and cost of goods transaction_type like 'SELLER_%' -- FORGIVEN action records will "negate" related INVOICED and action in ('INVOICED','FORGIVEN') ;
Ejemplo 4: Importe que el vendedor puede recaudar
Para saber cuánto pueden recaudar los vendedores, puede ejecutar una consulta como la que se muestra en el siguiente ejemplo. En este ejemplo se eliminan las tarifas e impuestos de publicación que AWS recauda y se agregan los ajustes de saldo excepcionales.
SELECT sum(amount) FROM billing_event WHERE (transaction_type like 'SELLER_%' -- what is invoiced on behalf of SELLER or transaction_type like 'AWS_REV_%' -- what is owed to AWS or transaction_type = 'BALANCE_ADJUSTMENT' -- exceptionnal case ) and action in ('INVOICED','FORGIVEN') ;
También puede utilizar la siguiente consulta para recopilar la misma información, como se muestra en el ejemplo siguiente.
SELECT sum(amount) FROM billing_event WHERE balance_impacting = 1 and action in ('INVOICED','FORGIVEN') ;
En el siguiente ejemplo se muestra la misma información, pero está restringida a las transacciones de 2018 y supone que todos los compradores pagaron sus facturas.
SELECT sum(amount) FROM billing_event WHERE invoice_date between '2018-01-01' and '2018-12-31' and balance_impacting = 1 and action in ('INVOICED','FORGIVEN') ;
Ejemplo 5: Importe de los desembolsos
Para averiguar la cantidad que se ha desembolsado, puede ejecutar una consulta como la que se muestra en el siguiente ejemplo.
select sum(amount) FROM billing_event WHERE action ='DISBURSED' and transaction_type like 'DISBURSEMENT%' ;
Ejemplo 6: Importe pendiente de desembolso
Para averiguar el importe pendiente de desembolso, puede ejecutar una consulta como la que se muestra en el siguiente ejemplo. Esta consulta elimina los importes que ya se han desembolsado.
SELECT sum(amount) FROM billing_event targeted WHERE (transaction_type like 'SELLER_%' -- what is invoiced on behalf of SELLER or transaction_type like 'AWS_REV_%' -- what is owed to AWS or transaction_type = 'BALANCE_ADJUSTMENT' -- exceptionnal case ) -- DISBURSEMENT action records will "negate" 'INVOICED' -- but do not take into account failed disbursements AND (not exists (select 1 from billing_event disbursement join billing_event failed_disbursement on disbursement.billing_event_id=failed_disbursement.parent_billing_event_id where disbursement.transaction_type='DISBURSEMENT' and failed_disbursement.transaction_type='DISBURSEMENT_FAILURE' and targeted.disbursement_billing_event_id=disbursement.billing_event_id ) ) ;
Otra forma de obtener la misma información es ejecutar una consulta como la que se muestra en el siguiente ejemplo para obtener el saldo del vendedor:
SELECT sum(amount) FROM billing_event WHERE balance_impacting = 1 ;
En la siguiente consulta se amplía nuestro ejemplo. Restringe los resultados a las transacciones de 2018 y devuelve más detalles sobre las transacciones.
select sum(residual_amount_per_transaction) from (SELECT max(billed_invoices.amount) invoiced_amount, sum(nvl(disbursed_invoices.amount,0)) disbursed_amount, -- Exercise left to the reader: -- use transaction_type to distinguish listing fee vs seller-owed money -- still pending collection max(transaction_type) transaction_type, max(billed_invoices.amount) + sum(nvl(disbursed_invoices.amount,0)) residual_amount_per_transaction FROM billing_event billed_invoices -- find related disbursements left join billing_event disbursed_invoices on disbursed_invoices.action='DISBURSED' and disbursed_invoices.parent_billing_event_id=billed_invoices.billing_event_id WHERE billed_invoices.invoice_date between '2018-01-01' and '2018-12-31' and billed_invoices.transaction_type like 'SELLER_%' -- invoiced on behalf of SELLER and billed_invoices.action in ('INVOICED','FORGIVEN') -- do not take into account failed disbursements AND not exists (select 1 from billing_event failed_disbursement where disbursed_invoices.disbursement_billing_event_id = failed_disbursement.parent_billing_event_id ) GROUP BY billed_invoices.billing_event_id );
Ejemplo 7: Saldo del conjunto de facturas
Para conocer la suma de un conjunto de facturas, puede ejecutar una consulta como la que se muestra en el siguiente ejemplo.
SELECT invoice_id, sum(amount) FROM billing_event targeted WHERE -- invoice_id is only not null for invoiced records AND disbursed records -- linking them to related disbursement -> no need to filter more precisely invoice_id in ('XXX','YYY') -- filter out failed disbursements AND not exists (select 1 from billing_event disbursement join billing_event failed_disbursement on disbursement.billing_event_id=failed_disbursement.parent_billing_event_id where disbursement.transaction_type='DISBURSEMENT' and failed_disbursement.transaction_type='DISBURSEMENT_FAILURE' and targeted.disbursement_billing_event_id=disbursement.billing_event_id ) group by invoice_id;