Migrating from Detailed Billing Reports to Cost and Usage Reports - Amazon Data Exports
Services or capabilities described in Amazon Web Services documentation might vary by Region. To see the differences applicable to the China Regions, see Getting Started with Amazon Web Services in China (PDF).

Migrating from Detailed Billing Reports to Cost and Usage Reports

Detailed Billing Reports (DBR) and Amazon Cost and Usage Reports (Amazon CUR) both provide information about your charges. However, if you're using DBR, we recommend you transfer your report to Cost and Usage Reports.

Comparing benefits of the Cost and Usage Reports (Amazon CUR)

Amazon CUR provides the most comprehensive source of information. You can use Amazon CUR to understand individual costs in depth, and to analyze them in greater detail. This is especially useful at an enterprise scale. Amazon CUR is helpful if you have complex cost management needs and require dedicated query or analytic-based systems. Amazon CUR also provides detailed information about Reserved Instances (RI), including amortized costs.

Comprehensive reservation information

Reserved Instances (RI), or reservations, offer a discounted hourly rate compared to On-Demand usage in exchange for committing to a one- or three-year term of service. This can result in significant savings. You can use Amazon CUR to monitor and manage your reservation portfolio. Amazon CUR provides you with detailed information, such as reservation Amazon Resource Numbers (ARNs), numbers of reservations, and total RIs. You can track your reservation-related discounts to specific resources to build a better understanding of your savings.

Detail Billing Reports (DBR) provide a subset of this metadata, but work is required to transform the required columns.

Amazon CUR provides additional columns that are not available in DBR, such as information regarding your amortized reservation costs. For more information, see Understanding your amortized reservation data.

On-Demand pricing availability

Amazon CUR provides information regarding the On-Demand rates for each individual line item of usage. You can use this information to quantify your savings by subtracting the amount you paid from the On-Demand rate. This also gives you the flexibility of choosing to allocate your costs using public On-Demand rates.

DBR doesn’t contain information for On-Demand rates, but only the billed amount. This makes it difficult to calculate your overall savings or to allocate costs using On-Demand rates.

Granular breakdown of discounts

Amazon CUR can access a granular view of the usage-based discounts. If discounts were applied, you can use Amazon CUR to view the following:

  • Cost before being discounted

  • Discounted amount

  • Total cost after the discount was applied at the line item level

DBR does not contain a granular breakdown of your discounts.

Automated data ingestion at scale

When you use Amazon CUR, you can easily configure an event to trigger an automated data ingestion process, streamlining the process of refreshing the billing data in your in-house systems. Amazon CUR data can automatically be refreshed when charges related to previous months are detected.

Additionally, Amazon CUR is generated as multiple files, providing the added benefit of segmenting the data into smaller pieces. This way, you can ingest the data according to the processes used by multiple workers. Moreover, you can retry data downloads in smaller pieces.

Amazon CUR is formatted in a way that enables you to locate and extract data quickly. This report is modeled from a manifest file that contains information for the overall structure of the data. This includes a list of every column that's contained in the report. Using this information, you can extend the report and include new information regarding your usage when it becomes available.

Cross-product integration

Amazon CUR is integrated with Amazon Redshift, Amazon QuickSight, and Amazon Athena. You can use Amazon CUR to build an Amazon-based cost management solution. Amazon CUR also provides data in Parquet format. This provides you with more options for building out your own cost and usage reporting system. For more information, see Amazon Cost and Usage Reports Manifest Files in the Amazon Billing User Guide.

Key differences between Detailed Billing Reports and Cost and Usage Reports

There are a few differences between DBR and Amazon CUR to consider after you migrate to Amazon CUR. For example, you might need to adjust how you ingest the data into your systems.

File structure

Detailed Billing Reports (DBR) are delivered as a single file. In contrast, Amazon CUR are a consolidated set of files. In Amazon CUR, you can view the following files in your Amazon S3 bucket:

  • A set of data files that contain all of your usage line items

  • A separate data file that contains all of your discounts (if applicable)

  • A manifest file that lists all of the data files that belong to a single report

Column structure

DBR have a fixed list of columns, limiting its flexibility. Amazon CUR don't have a fixed column structure, and instead allow you to freely add or remove columns as needed. When you begin using a new Amazon Web Services service, Amazon CUR can dynamically start to include new data in the report that might be useful in your case. The manifest file provides a map of all columns present in the report.

Equivalent Column Names for DBR and Amazon CUR
DBR column name Amazon CUR column name
InvoiceId bill/InvoiceId
PayerAccountId bill/PayerAccountId
LinkedAccountId lineItem/UsageAccountId
ProductName product/ProductName
SubscriptionId reservation/subscriptionid
UsageType lineItem/UsageType
Operation lineItem/Operation
AvailabilityZone lineItem/AvailabilityZone
ReservedInstance Not Supported
ItemDescription lineItem/LineItemDescription
UsageStartDate lineItem/UsageStartDate
UsageEndDate lineItem/UsageEndDate
UsageQuantity lineItem/UsageAmount
BlendedRate lineItem/BlendedRate
BlendedCost lineItem/BlendedCost
UnBlendedRate lineItem/UnblendedRate
UnBlendedCost lineItem/UnblendedCost
ResourceId lineItem/ResourceId
RecordType Not Supported
PricingplanId Not Supported
RateID pricing/RateId
Note

There's no equivalent for RecordId in Amazon CUR. But, you can gather this information by combining identity/LineItemId, identity/TimeInterval, and bill/BillType.

Retrieving DBR RecordType values through Amazon CUR
RecordType values in DBR Syntax to retrieve RecordType through Amazon CUR Use case
LineItem SELECT SUM(line_item_unblended_cost) FROM [CUR] WHERE line_item_line_item_type = 'Usage' Usage line item partitions out usage costs from one-time charges (for example, upfront RI payment).
InvoiceTotal SELECT (bill_invoice_id), sum(line_item_unblended_cost) FROM [CUR] GROUP BY bill_invoice_id You can use invoice total to reconcile your costs between Invoices and Cost and Usage Reports.
AccountTotal SELECT line_item_usage_account_id, sum(line_item_unblended_cost) FROM [CUR] GROUP BY line_item_usage_account_id You can use account total to isolate costs related to your member accounts for charge back purposes.
StatementTotal SELECT SUM(line_item_unblended_cost) FROM [CUR] You can use statement total to understand your costs for the billing period.
Discount SELECT SUM(line_item_unblended_cost) FROM [CUR] WHERE line_item_line_item_type = 'Discount' You can use discount line items to identify all of your discount-related line items.
Rounding Not yet supported Not yet supported

Reporting on advanced charge types

Refunds

Amazon CUR: Refunds are identified by filtering for the lineItem/LineItemDescription = ‘Refund’ string.

DBR: Refunds are identified by checking the ItemDescription column for the ‘Refund’ substring.

Credits

Amazon CUR: Credits are identified by filtering for the lineItem/LineItemDescription = ‘Credit’ string.

DBR: Credits are identified by checking the ItemDescription column for the ‘Credit’ substring.

Taxes

Amazon CUR: Taxes are identified by filtering for the lineItem/LineItemDescription = ‘Tax’ string.

DBR: Taxes are identified by checking the ItemDescription column for the ‘Tax’ substring.

Identifying reservation-related upfront costs

Amazon CUR: Reservation-related upfront costs are identified by filtering for the "lineItem/LineItemType" = 'Fee' string.

DBR: Reservation-related upfront costs are identified by checking the UsageType column for the 'HeavyUsage' substring, and whether the 'SubscriptionId' is null.

Identifying reservation-related monthly fees

Amazon CUR: Reservation-related monthly fees are identified by filtering for the "lineItem/LineItemType" = 'RIfee' string.

DBR: Reservation-related monthly fees are identified by checking the UsageType column for the 'HeavyUsage' substring.

Identifying instances that received reserved instance benefits

Amazon CUR: Reservation-related upfront fees are identified by filtering for the "lineItem/LineItemType" = 'DiscountedUsage' string.

DBR: Reservation-related upfront fees are identified by checking the ReservedInstance column for the 'Y' substring.