Microsoft provided object numbering convention to follow for Dynamics NAV and please check the below link for more information, it is important to follow this Conventions while making customizations as it will help to upgrade easily and support.
https://msdn.microsoft.com/en-us/library/ee414238(v=nav.90).aspx
Below content is copied from Microsoft website
Each object and field in Microsoft Dynamics NAV is identified by a number that is stored in its ID Property. This topic describes the numbering scheme for the development environment. Numbering conventions that are used in the CRONUS International Ltd. demonstration database and guidelines for objects and fields that are outside the demo range are described.
The Numbering System
The objects ranges in Microsoft Dynamics NAV are described in the following table.
The fields in Microsoft Dynamics NAV are grouped as indicated in the following table.
When a Microsoft Certified Partner buys the insert permissions for a table number interval, such as 200,000–200,099, the partner also gets insert permissions for the same number interval (200,000–200,099) for fields in all other tables. If you create a table in the range for which you have insert permissions, then you can create fields in all field number intervals in the table. However, we recommend that you use only the field numbers that are in the same number interval as the table number interval so that fields in solutions from different partners do not interfere with each other.
Objects
The numbering conventions for objects depend on the object type. Conventions for the following types are described in the following sections:- Tables
- Pages
- Reports
- Codeunits
Table object numbers are not divided into intervals in the CRONUS International Ltd. demonstration database. Use the first available object number when you create a table. Try to group related tables together.
Pages
Page object numbers are not divided into intervals in the CRONUS International Ltd. demonstration database. Use the first available object number when you create a page. Try to group related pages together.
Reports
Report objects are numbered in intervals in the CRONUS International Ltd. demonstration database. The following table displays the interval for each application area.
Report number interval | Application areas |
1 - 99 | General Ledger, including VAT and Consolidation |
100 - 199 | Accounts Receivable |
200 - 299 | Sales |
300 - 399 | Accounts Payable |
400 - 499 | Purchases |
500 - 599 | Common to both Purchases and Sales, including Exchange Rate |
600 - 699 | Requisition |
700 - 799 | Item, including Intrastat |
800 - 899 | Bill of Materials |
900 - 999 | Item Group |
1000 - 1099 | Inventory (common to Item, BOM, and Item Group) |
1100 - 1199 | Resource |
1200 - 1299 | Job |
1300 - 1399 | General |
1400 - 9899 | Future areas |
9900 - 9999 | Utilities |
If you create a new report that does not belong in one of the existing application areas or if you create a new report and the area in which it belongs is full, then use a number from a new interval of length 100 and between 1,400 and 9,899.
If a report object can be printed, then it is called a report. Otherwise, it is called a batch job. Reports are numbered starting at the lower end of the interval. Batch jobs are numbered starting at the higher end of the interval with decreasing numbers.
We recommend that you number reports that are almost identical in the application areas with the same two final digits even if the report name is different. For example, the Sales Invoice report in the CRONUS International Ltd. demonstration database is number 206 and the Purchase Invoice report is number 406. Other examples are the date compression batch jobs for ledger entry tables, which always end with 98, and date compressions for budget entries, which always end with 97. This practice may cause gaps in the numbering sequence, but it helps the developer when adjustments to similar reports in the application are needed.
Codeunits
Codeunit object numbers are not divided into intervals in the CRONUS International Ltd. demonstration database. Use the first available object number when you create a codeunit. Try to group related codeunits together.
The journal posting codeunits follow a pattern that makes it easier to understand a new journal after you are familiar with one group of journal posting codeunits.
A group consists of two parts:
- Codeunits in the first part post a journal.
- Codeunits in the second part manage the journals.
Codeunit final digit | Journal posting codeunits |
1 | Journal Line-Check |
2 | Journal Line-Post |
3 | Batch Name-Post |
Codeunit final digit | Journal managing codeunits |
0 | Journal-Management |
1 | Journal-Post |
2 | Journal-Post+Print |
3 | Journal-Batch Post |
4 | Journal-Batch Post+Print |
5 | Register-Show Ledger |
Codeunit final digit | Sales/Purchase Posting Codeunits |
0 | Sales/Purchase Post |
1 | Sales/Purchase Post (Yes/No) |
2 | Sales/Purchase Post+Print |
When you create codeunits for the sales application areas, use the same final digit for similar purchase application areas.
Table Fields
When you assign numbers to new fields in a table, consider whether the table is associated with other related tables. If so, then you may want to also add the fields to these related tables. In this case, the field must have the same field number in all tables. For example, if you add a new field to the Customer table but do not add the field to the Vendortable, then you still must reserve that field number in the Vendor table for the new field from the Customer table. It is easier to maintain the application when the tables look very similar.
Examples of associated tables are as follows:
- Customer and Vendor tables
- Journal template tables
- Batch name tables
- Journal line tables
- Sales Header, Sales Shipment Header, Sales Invoice Header, and Sales Credit Memo Header tables
- Purchase Line, Purchase Receipt Line, Purchase Invoice Line and Purchase Credit Memo Line tables
Please leave your comments, feedback or any suggestions you have for me to improve me my blog and also if you have any questions, feel free to post..
1 comments:
Hi Kulla
Thank you for a great blog post.
I have never seen the 99,000-99,999 range in the training material.
However, in the C/Side Solution Development they use the
123,456,700-123,456,799 range.
I also have a few additions that I always include in my courses:
1,000,000,000 - 1,099,999,999 A restored backup that has gone bad
2,000,000,000 - 2,099,999,999 System and Virtual objects
Thank you and keep up the good work
/Peik
Post a Comment