Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
In Microsoft Dynamics 365 Finance and Dynamics 365 Supply Chain Management, cleanup routines are available in various modules. This article provides an overview of the routines that are currently available. The information is organized according to modules.
Important
These cleanup routines should be run only after the business has done detailed analysis and confirmed that the data is no longer required.
Always test each cleanup routine in a test environment before you run it in a production environment.
System administration
| Path | Description | 
|---|---|
| System administration > Periodic tasks > Notification clean up | This cleanup routine is used to periodically delete records from the EventInbox and EventInboxData tables. Recommendation: If you don't use alert functionality, turn off the alert from the batch job. | 
| System administration > Periodic tasks > Batch job history clean-up | This regular version of the batch job history cleanup routine lets you quickly clean all history entries that are older than a specified number of days. Any entry that was created earlier is deleted from the BatchJobHistory table, and also from linked tables with related records (BatchHistory and BatchConstraintsHistory). This version offers better performance optimization, since it eliminates the need for filtering. | 
| System administration > Periodic tasks > Batch job history clean-up (custom) | This custom batch job history cleanup routine should be used only when specific entries must be deleted. You can clean up selected types of batch job history records, based on criteria such as status, job description, company, or user. You can add other criteria by using the Filter button. | 
| System administration > Periodic tasks > Batch job clean-up | Clean up the batch job table should be used regularly to clean up the batch job table. In Retain jobs (days) field, specify the number of days to keep the records of batch jobs. This cleanup should be done outside business hours. | 
| System administration > Inquiries > Database > Database Log > Clean up log | This cleanup routine lets you delete database logs as you require. You can delete logs for specific tables, delete specific types of database logs, or delete logs based on the date and time when they were created. Note: Records electronically signed can't be deleted from logs. | 
Data management
| Path | Description | 
|---|---|
| In the Data management workspace, select Job history cleanup. | By default, job history entries and related staging table data that are older than 90 days are automatically deleted (starting September 2023). To configure a job history retention period of less than 90 days, use the Execution history cleanup feature in Data management. It replaces the earlier Staging cleanup routine, which is now obsolete (deprecated). The following tables are cleaned up: 
 | 
General ledger
| Path | Description | 
|---|---|
| General ledger > Periodic tasks > Clean up ledger journals | This cleanup routine deletes General ledger, Accounts receivable, and Accounts payable journals that are posted. When you delete a posted ledger journal, all information that is related to the original transaction is removed. Note: Delete this information only if you're sure that reversing the ledger journal transactions aren't necessary. | 
Retail and Commerce
| Path | Description | 
|---|---|
| Retail and Commerce > Retail and Commerce IT > Email and notifications > Clean up email notification logs | This cleanup routine sets up a batch job to clean up the email notification logs. | 
Sales and marketing
| Path | Description | 
|---|---|
| Sales and marketing > Periodic tasks > Clean up > Delete sales orders | This cleanup routine deletes selected sales orders. | 
| Sales and marketing > Periodic tasks > Clean up > Delete quotations | This cleanup routine deletes selected quotations. | 
| Sales and marketing > Periodic tasks > Clean up > Delete return orders | This cleanup routine deletes selected return orders. | 
| Sales and marketing > Periodic tasks > Clean up > Sales update history cleanup | This cleanup routine deletes old update history transactions. All updates of confirmations, picking lists, packing slips, and invoices generate update history transactions. You view these transactions on the History on update page. | 
| Sales and marketing > Periodic tasks > Clean up > Order events cleanup | This cleanup routine cleans up order events. The next step is to open the Order event setup page and clear the check boxes for any order events that aren't required. | 
Procurement and sourcing
| Path | Description | 
|---|---|
| Procurement and sourcing > Periodic tasks > Clean up > Purchase update history cleanup | This cleanup routine is used to delete all updates of confirmations, picking lists, product receipts, and invoices that generate update history transactions. | 
| Procurement and sourcing > Periodic tasks > Clean up > Delete requests for quotations | This cleanup routine is used to delete requests for quotation (RFQs) and RFQ replies. The corresponding RFQ journals aren't deleted but remain in the system. | 
| Procurement and sourcing > Periodic tasks > Clean up > Draft consignment replenishment order journal cleanup | This cleanup routine is used to clean up draft consignment replenishment order journals. | 
Warehouse management
| Path | Description | 
|---|---|
| Warehouse management > Periodic tasks > Clean up > Work creation history cleanup | This cleanup routine is used to delete work creation history records from the WHSWorkCreateHistorytable table. In the dialog box, you specify the number of days to keep the history. | 
| Warehouse management > Periodic tasks > Clean up > Containerization history cleanup | This cleanup routine is used to delete containerization history from the WHSContainerizationHistory table. In the dialog box, you specify the number of days to keep the history. | 
| Warehouse management > Periodic tasks > Clean up > Wave processing history log cleanup | This cleanup routine is used to delete the wave processing history log records from the WHSWaveExecutionHistory table. In the dialog box, you specify the number of days to keep the history. | 
| Warehouse management > Periodic tasks > Clean up > Wave batch cleanup | This cleanup routine is used to clean up batch job history records that are related to the wave processing batch group. | 
| Warehouse management > Periodic tasks > Clean up > Cycle count plan cleanup | This cleanup routine is used to clean up batch job history records that are related to cycle count plan configurations. | 
| Warehouse management > Periodic tasks > Clean up > Mobile device activity log cleanup | This cleanup routine is used to delete mobile device activity log records from the WHSMobileDeviceActivityLog table. In the dialog box, you specify the number of days to keep the history. | 
| Warehouse management > Periodic tasks > Clean up > Work user session log cleanup | This cleanup routine is used to delete work user session records from the WHSWorkUserSessionLog table. In the dialog box, you specify the number of hours to keep records. | 
| Warehouse management > Periodic tasks > Clean up > Wave labels cleanup | This cleanup routine is used to clean up the wave label records from the WHSWaveLabel table. | 
| Warehouse management > Periodic tasks > Clean up > Work line history log cleanup | This cleanup routine is used to delete the temporary work history records from the WHSTmpWorkLineHistory table. In the dialog box, you specify the number of days to keep the history. | 
| Warehouse management > Periodic tasks > Clean up > Clean up License plate registration history | This cleanup routine is used to delete the license plate receiving history records from the WHSLicensePlateReceivingHistory. In the dialog box, you specify the number of days to keep the history. | 
| Warehouse management > Periodic tasks > Clean up > Clean up work exceptions log | This cleanup routine is used to delete work exceptions log records from the WHSWorkExceptionLog table. In the dialog box, you specify the number of days to keep in the history, the status of the entries to be deleted (that is, Open or Closed) and the maximum number of records that this operation can delete. Learn more in View and manage the work exceptions log. | 
Inventory management
The following table describes the cleanup jobs that are available for the Inventory management module. Each of them is listed under the Inventory management > Periodic tasks > Clean up path in the navigation pane at the left side of the page. You can also find any of them by entering the job name directly into the Search for a page field in the navigation bar at the top of the page.
| Job name | Description | 
|---|---|
| Calculation of location load | The WMSLocationLoadtable tracks the weight and volume of items and pallets. The Calculation of location load job reduces the number of records in theWMSLocationLoadtable and helps improve performance. | 
| Inventory journals cleanup | This cleanup routine deletes posted inventory journals. Cleaning up posted inventory journals help free system resources. | 
| Inventory settlements cleanup | This cleanup routine groups closed inventory transactions or deletes canceled inventory settlements. By cleaning up closed or deleted inventory settlements, you help free up system resources. Don't group or delete inventory settlements that are too close to the current date or fiscal year, because part of the transaction information for the settlements that are lost. Closed inventory transactions can't be changed after they're grouped, because the transaction information for the settlements is lost. If canceled inventory settlements are deleted, they can't be reconciled with finance transactions. The dialog for setting up this job provides the following optional settings: 
 | 
| Inventory dimensions cleanup | This cleanup routine maintains the  This cleanup routine verifies whether each  Inventory dimension combination records that are still referenced can't be deleted because when an  Warning: This job deletes all inventory dimensions that were created during the targeted date range and which are defined but not used in the current company. Unused inventory dimensions are deleted permanently. No alert or database log is created during the process. Don't run this job without a good reason. Be sure to schedule this process to run outside of business hours. | 
| On-hand entries cleanup | This cleanup routine deletes closed and unused entries for on-hand inventory that is assigned to one or more tracking dimensions. Closed transactions are marked as closed and contain a value of 0 (zero) for all quantities and cost values. By deleting these transactions, you help improve the performance of queries for on-hand inventory. Transactions aren't deleted for on-hand inventory that isn't assigned to tracking dimensions. This cleanup routine can remove data used by reports such as the physical inventory by inventory dimension report, so make sure you understand the implications before running it. The dialog for setting up this job provides the following setting: 
 | 
| Warehouse management on-hand cleanup | This cleanup routine deletes records in the InventSumandWHSInventReservetables. These tables are used to store on-hand information for items that are enabled for warehouse management processes (that is, WHS items). By cleaning up these records, you significantly improve the performance of on-hand calculations. However, this cleanup routine can remove data used by reports such as the physical inventory by inventory dimension report, so make sure you understand the implications before running it. | 
| On-hand entries aggregation by financial dimensions | This cleanup routine aggregates  This routine handles scenarios where there are no more quantities in the  For example, if you use batch numbers, each batch number (and the combined site, warehouse, and so on) creates a new record in the  Inventory values are determined by records in the  The data from the individual records at the batch-number level are never used. Therefore, this routine goes through all  | 
| Cost calculation details | This cleanup routine cleans up cost calculation details. | 
| Transfer order update history cleanup | This cleanup routine deletes records from the InventTransferParmTable,InventTransferParmUpdateandInventTransferParmLinetables. These tables are used when posting transfer orders. This cleanup helps improve the performance of any function that queries these tables. | 
| Inventory transaction consolidation | This cleanup routine consolidates data about inventory transactions to help improve system performance. For more information about this functionality, see Consolidate inventory transactions. | 
| Inventory on-hand report data clean up | This cleanup routine deletes on-hand storage data for reports that were executed before a specific date. The dialog for setting up this job provides the following setting: 
 | 
| Correct inventory transfer order lines manually | This cleanup routine fixes inconsistent data and corrects unexpected quantities that are related to transfer orders. The dialog for setting up this job provides the following settings: 
 | 
| Inventory journal data correction | This cleanup routine deletes all on-order or ordered inventory transactions that link to posted or nonexistent inventory journals in the current company. You choose whether or not to clean up orphan unposted inventory transactions without journal lines. Warning: The inventory transactions are deleted permanently. No alert or database log is created during the process. Don't run this process without a good reason, and be sure to test carefully before running it in the production environment. | 
| Correct item that isn't visible in released products form manually | This cleanup routine solves display problems such as released products not displaying and e-commerce catalogs not working after you deploy a proactive quality update (PQU) for your system. It works by making sure the InventDimtable includes a record where theInventDimIdfield has a value of AllBlank, and that records in theInventItemLocationtable correctly relate to this record through theInventItemLocation.InventDimIdfield as needed. | 
Production control
| Path | Description | 
|---|---|
| Production control > Periodic tasks > Clean up > Production journals cleanup | This cleanup routine is used to delete unused journals. | 
| Production control > Periodic tasks > Clean up > Production orders cleanup | This cleanup routine is used to delete production orders that are ended. | 
| Production control > Periodic tasks > Clean up > Clean up registrations | We recommend that you periodically clean up registrations. This cleanup routine deletes only data that is processed. Note: Make sure that you don't delete registrations that might be required later for documentation purposes. | 
| Production control > Periodic tasks > Clean up > Archive future registrations | This cleanup routine is used to remove future registrations from the raw registrations table. | 
Cost management
| Path | Description | 
|---|---|
| Cost management > Manufacturing accounting > Clean up > Production orders cleanup | Same as Production control > Periodic tasks > Clean up > Production orders cleanup. | 
| Cost management > Manufacturing accounting > Clean up > Production recalculation | Bundles production orders where the estimated costs for material and time consumption should be recalculated and schedules recalculation tasks. | 
| Cost management > Manufacturing accounting > Clean up > Clean up the costing sheet cache | The CostSheetCache table is used as a temp location for cost sheets to help generate prices. This job cleans up the costing sheet cache. Records in the cache that have an age of the specified days or older are deleted. | 
Master planning
| Path | Description | 
|---|---|
| Master planning > Master planning > Maintain plans > Plan version cleanup | Usually, this cleanup is done automatically. However, automatic cleanup sometimes malfunctions, and orphan data remains in the system. This orphan data slows down queries and causes the database size to grow. We recommend that you do a preventive run one time per month, when master resource planning (MRP) isn't running. | 
Project management and accounting
| Path | Description | 
|---|---|
| Project management and accounting > Periodic > Delete project journals | This cleanup routine deletes project hour fee, and beginning balance journals that have been posted. When you delete a posted ledger journal, all information that is related to the original transaction is removed. Note: You should delete this information only if you're sure that you won't have to reverse the ledger journal transactions. |