See how Insoft Services is responding to COVID-19

Developing Solutions for Microsoft Dynamics NAV 2018 and 365 Business Central


Student Registration Form

Thank you for being interested in our training! Fill out this form to pre-book or request information about the delivery options.

* Required

Course Schedule

I'd like to receive emails with the latest updates and promotions from Insoft.

Data Protection & Privacy

I hereby allow Insoft Ltd. to contact me on this topic. Further, I authorise Insoft Ltd. processing, using collecting and storing my personal data for the purpose of these activities. All your data will be protected and secured as outlined in our privacy policy.

Course Schedule

  • 6 Days Course
    Microsoft Dynamics NAV

    Classroom + Online

    ISK462000 (Excl. VAT)
    Book Now

    Course Details


    Get your Developing Solutions for Microsoft Dynamics NAV 2018 and 365 Business Central training in just 6 days and learn more than you could imagine.

    This training focuses on the capabilities and features of the Microsoft Dynamics NAV 2018 Development Environment. It explains the basic development concepts in Microsoft Dynamics NAV 2018 and provides an overview of the C/AL programming language and various object types. It also covers new development capabilities, including reporting, queries, and .NET Framework interoperability. It also introduces programming using events and how to compile all into an extension V. 1.0

    This training also leads individuals through a simulated implementation project, where the goal is to customize Microsoft Dynamics 365 BC to meet customer’s requirement. It explains standard application concepts and provides insight into most important processes in Microsoft Dynamics 365 BC, including documents and journals posting, dimension management, feature integration, role tailoring, and automating unit testing.

    The solution will be created purely as an extension in Visual Studio Code, without changing a single object in the standard application of Microsoft Dynamics 365 BC.

    During your 6-day Training Programme, you will live and learn at our Training Center.

    At Insoft, we know your time is valuable. That’s why we give you the opportunity to gain your Developing Solutions for Microsoft Dynamics NAV 2018 and 365 Business Central training in just 6 days. We provide the best conditions for you to learn.

    With us by your side, encouraging and guiding you along the way, you can enjoy 6 intense, focused days of quality learning in a distraction free environment. Your expert instructor will be working with Insoft’s unique accelerated learning methods, which include our exclusive lecture/lab/review methodology with real life cases putting you in the best possible position to learn and retain knowledge.

    Sitting your Developing Solutions for Microsoft Dynamics NAV 2018 and 365 Business Central course with Insoft means:

    • You’ll get more hours of training per day, allowing you to get trained faster and more cost-effectively than with any other training provider.
    • You will be trained by one of the most expert instructors in the world.
    • You can focus purely on learning in our distraction free environment.
    • Dedicated onsite support and access to your classroom at all hours.
    • The price you pay is all-inclusive and covers all course materials, transportation service, accommodation and meals.

    This course can also be split up by taking the following courses separate:


    We have designed our course material in the way that best prepares you to learn.

    Microsoft Dynamics NAV 2018 Integrated Development Environment

    At Training Completion

    After completing this training, individuals will be able to:

    • Present the basic object types in Microsoft Dynamics NAV 2018.
    • Describe fundamental aspects of Microsoft Dynamics NAV 2018.
    • Development Environment. This includes the UI, application objects, and basic metadata concepts.
    • Explain the physical and logical database structure.
    • Explain the features for multi-developer environments.
    • Explain the concepts of tables and table components.
    • Examine the concept behind primary and secondary keys and explain how to set them.
    • Create a simple table with primary and secondary keys and add data to the table.
    • Review the concept of table relations.
    • Set table relations with a filter and condition.
    • Describe special table fields.
    • Use special table fields to improve table features.
    • Explain the concepts of pages and page components.
    • Describe Page Designer and Action Designer.
    • Create a simple page and add basic controls to the page.
    • Provide an overview of different page types and their characteristics.
    • Discuss best practices in designing pages.
    • Create a Card page, add a container, FastTabs, and fields.
    • Create a List page and link it to the Card page.
    • Create a main page and a Part page and link the two pages.
    • Describe the concepts and basic use of C/AL code elements.
    • Describe the concepts of data types, simple data types, and complex data types.
    • Explain the concepts of identifiers, variables, and syntax.
    • Explain the syntax of identifiers.
    • Explain the scope of variables.
    • Explain the initialization of variables.
    • Create a simple codeunit to show how to define variables, assign data types, and investigate several default values that are initialized for several data types.
    • Explain the concepts of assignment, statement, and assignment statements.
    • Describe the syntax of statements and introduce the statement separator.
    • Describe automatic type conversions for string, numeric, and other data types.
    • Use assignment statements and the Symbol Menu.
    • Understand the concepts of expressions, terms, and operators.
    • Describe the syntax of an expression.
    • Describe the string operator.
    • Use the string operator.
    • Describe the MAXSTRLEN and the COPYSTR functions.
    • Use the MAXSTRLEN and the COPYSTR functions in an expression.
    • Define numeric expressions, arithmetic operators, and operator precedence.
    • Describe the arithmetic operators and provide examples.
    • Use the arithmetic operators and examine the operator precedence.
    • Define relational and logical operators and expressions.
    • Describe how to use relational expressions for comparison.
    • Describe how to use relational expressions for set inclusion.
    • Describe how to use logical expressions.
    • Use logical and relational expressions in a page.
    • Define conditional statements and Boolean expressions.
    • Describe the IF statement, the IF-THEN, and IF-THEN-ELSE syntax.
    • Describe the EXIT statement and code indentation.
    • Describe the CASE statement and the syntax of the CASE statement.
    • Define compound statements and comments.
    • Describe the syntax of compound statements with BEGIN and END.
    • Understand the concepts of nested IF statements and the rule of correct indentation.
    • Describe the syntax of comments.
    • Use the IF, EXIT, CASE, and compound statements in a page.
    • Test knowledge about C/AL statements.
    • Define arrays and describe the components of arrays.
    • Describe the syntax of arrays.
    • Explain the power of arrays.
    • Describe how to use strings as arrays of characters.
    • Introduce repetitive statements that are available in C/AL.
    • Use arrays and repetitive statements in a page.
    • Describe the WITH statement, record variables, and the syntax of the WITH statement.
    • Explain the concepts of functions and parameters.
    • Explain the C/AL Symbol Menu.
    • Describe the use and syntax of data access, filtering, and manipulation functions.
    • Describe the use and syntax of user interaction functions.
    • Describe the use and syntax of string functions.
    • Describe the use and syntax of system functions.
    • Describe the use and syntax of date functions.
    • Describe the use and syntax of number functions.
    • Describe the use and syntax of array functions.
    • Describe the use and syntax of several other important functions.
    • Provide an overview of the benefits of creating custom functions.
    • Explain the concepts of local functions and local variables.
    • Create custom functions in a page and call the functions from Actions.
    • Explain the concepts of reports and report components.
    • Provide an overview of different report types and their characteristics.
    • Describe the difference between the logical and the visual design of reports and introduce Report Designer.
    • Describe the logical design of a report.
    • Create the data model for a new report by defining data items in the Report Dataset Designer.
    • Describe the visual design of a report and introduce Microsoft Visual Studio Report Designer.
    • Design the report layout.
    • Introduce Request Page Designer.
    • Design the Request Options page.
    • Explain the concepts of grouping and totaling in a report.
    • Create a grouping and totaling for a report.
    • Add advanced features to a report.
    • Describe the fundamentals of an XMLport and its components.
    • Review how to design XMLports.
    • Explain the Request page functionality.
    • Describe how to use XMLports from C/AL code.
    • Create XMLports for export and import with XML format.
    • Create XMLports for export and import with a fixed and a variable text format.
    • Explain the concepts of codeunits.
    • Provide an overview of designing codeunits.
    • Provide an overview by using codeunits.
    • Define variables and functions in a codeunit.
    • Use the SMTP Mail codeunit.
    • Introduction to Business Events and Integration Events in the standard application
    • Creating codeunits containing event subscription
    • Creating extensions V. 1.0
    • Creating upgrade functions
    • Creating Upgrade Codeunits
    • Explain the .NET Interoperability features.
    • Describe the concept of constructors.
    • Communicate between client-side and server-side objects.
    • Describe how to respond to events that are raised by .NET objects.
    • Examine mapping between C/AL and .NET data types.
    • Review the most important C/AL functions for managing .NET objects.
    • Use arrays, collections, and enumerations.
    • Explain how to stream data between C/AL and .NET objects.
    • Present the Query Designer and its features
    • Explain the principles of the query design process
    • Show how to select, join, filter, aggregate, and order data
    • Demonstrate how to access queries from C/AL code
    • Explain how to export data from queries.

    Dynamics 365 Business Central/NAV 2018 Solution Development with Visual Studio Code

    Introduction to Visual Studio Code

    The course covers:

    • The Visual Studio Code Editor
    • Native Github integration
    • Using Snippets
    • Creating Snippets
    • Converting existing objects to AL
    • And of course, creating objects:
      • New Tables
      • Extending existing tables, including which properties can be changed and where to add code to triggers
      • New Pages
      • Extending existing pages, including which properties can be changed and where to add code to triggers
      • Creating codeunits, including:
        • Event subscriptions
        • Install Codeunits
        • Upgrade Codeunits
      • Creating reports in Dynamics 365 Business Central
      • Creating reports in Dynamics NAV 2018
      • Creating XML Ports
      • Creating Queries
    • Controlling the Departments menu
    • Design patterns in Dynamics NAV/Dynamics 365 BC
    • Using the Visual Studio Code editor with other extensions, like:
      • PowerShell
      • XML Documents
      • JSON Tools
      • Snippet Creator
    • Upgrading to extensions
    • Differences between solution development in Dynamics NAV 2018 and Dynamics 365 BC

    At Training Completion

    After completing this training, individuals will be able to:

    • Explain the different table types and their characteristics.
    • Present the standard data model and introduce the data-related business logic.
    • Present the standard process model that governs the transactions in Microsoft Dynamics 365 BC.
    • Explain the master table and page standards.
    • Work with table event triggers.
    • Work with complex data types and their member functions.
    • Explain the multilanguage functionality.
    • Define the strategy for implementing Customers and Participants.
    • Create the tables to manage the seminar rooms.
    • Create instructor data management.
    • Create seminar data management.
    • Import and export objects as text files.
    • Support multilanguage functionality.
    • Use document pages.
    • Use virtual tables.
    • Use temporary tables.
    • Review the various types of tables.
    • Review different page and table C/AL functions.
    • Create additional tables and pages to maintain registrations.
    • Explain the working and posting tables.
    • Explain the posting routines and their relationships.
    • Create journal posting routines.
    • Create document posting routines.
    • Present the best practices for documenting changes to existing objects.
    • Program for minimum effect on the application.
    • Integrate previously created Seminar Management module features with one another.
    • Explain the architecture of the Navigate feature.
    • Extend the Navigate functionality to enable finding posted seminar information.
    • Enable easier searching for information by adding Navigate functionality to Seminar Management pages.
    • Enable looking up Seminar Management information from standard application areas.
    • Use report event triggers.
    • Use special report functions.
    • Create reports for the RoleTailored client.
    • Create a seminar participant list.
    • Create a ProcessingOnly report that posts invoices.
    • Create a page that calculates price sums efficiently.
    • Make the page available from the Seminar pages.
    • Use FlowFilters to easily calculate statistics for different time periods.
    • Describe Global, Shortcut, and Budget dimension types and their functions.
    • List the basic rules of Dimension Setup.
    • Present the dimension management data and process models.
    • Implement dimensions on the master record level.
    • Define the components of the RoleTailored user interface.
    • Explain the structure, purpose, and functionality of a Role Center-type page.
    • Create the Seminar Manager Role Center page.
    • Describe the functionality of the Departments page and the MenuSuite object type.
    • Integrate the Seminar Management department into the Departments page.
    • Explain how to use Automation and OCX to perform tasks with other applications.
    • Describe file handling functions to import or export data.
    • Describe Microsoft Dynamics 365 BC Web services architecture.
    • Explain the protocols that Microsoft Dynamics 365 BC uses for Web services.
    • Evaluate the benefits of Web services over other integration options in Microsoft Dynamics NAV.
    • Explain how to expose codeunit, page, and query objects as Web services.
    • Consume Web services from external applications.
    • Describe the Debugger functionality and features.
    • Demonstrate the debugging process.


    Before attending this course you should have:

    • Knowledge of Microsoft Dynamics 365 BC
    • Knowledge of Microsoft Dynamics NAV 2018
    • Basic knowledge of programming concepts and programming languages.

    Do you have what it takes?
    We´ll help you decide – Call us to discuss your technical background, experience and qualifications to determine how we can help you succeed in this Insoft course.

    Just call us and speak to one of our enrolment consultants.