Skip to content

Importing Purchase Orders into Dynamics 365 Business Central

This task will create or update purchase orders in Dynamics 365 Business Central. The data must be supplied in the Dynamics 365 Business Central Purchase Order XML format.

Purchase orders are matched based on the following XML elements, in the order listed: Id, ExternalId, Number. If a match is found, the existing purchase order will be updated. If not, a new purchase order will be created.

When updating existing purchase order, the purchase order lines are matched based on the following XML elements, in the order listed: Id, ExternalId, Sequence, ItemId. If a match is found, the existing purchase order line will be updated. If not, a new purchase order line will be created.

Settings

Dynamics 365 Business Central Connection

Required
The connection to Dynamics 365 Business Central to use. See the Connecting to Dynamics 365 Business Central article if you require more information on how to create/manage connections.

Fail File

Required
The name of a file for records that fail to import to be output to. The data will be in the same XML format as the input file.

Input File

Required
The file containing the records that you want to import into Dynamics 365 Business Central. The records must be supplied in the XML format shown below.

Success File

Required
The name of a file for successfully imported records to be output to. The data will be in the same XML format as the input file.

Auto Create Items

Required

Set to true to have the task automatically create new items if they do not already exist and have been provided within the Item element of the XML. Setting this to false will cause the record to fail import if any of the items do not already exist.

Note

The LineObjectNumber element takes precedence over data provided in the Item element. It should not be specified if you want to auto create items.

Auto Create Vendors

Required

Set to true to have the task automatically create new vendors if they do not already exist, and have been provided within the Vendor or PayToVendor element of the XML. Setting this to false will cause the record to fail import if the vendors do not already exist.

Note

The VendorId, VendorNumber, PayToVendorId and PayToVendorNumber elements take precedence over data provided in the Vendor and PayToVendor elements. They should not be specified if you want to auto create vendors.

Auto Post

Required
Set to true to have the task automatically post each record.

Match Vendors On

Optional
The list of fields to use to try and find an existing vendor in Dynamics 365 Business Central which matches with the vendor in the input file. These settings will only be used if the vendor Id and Number are not provided in the input file, and the external ID is not found in the truth table. When multiple fields are selected, only vendors where the value of all the fields match will be considered a match. The following fields are supported:

  • DisplayName
  • Email
  • PhoneNumber
  • PostalCode

Prevent Reprocessing

Required
Set this to 'True' to check the value specified in the ExternalId element in the XML against the truth table to see if it has already been processed, and if so skip the record.

Zynk Settings

See Common Task Settings

Examples

Sample input file, for full documentation see Dynamics 365 Business Central Purchase Order XML:

<?xml version="1.0" encoding="utf-8"?>
<PurchaseOrders xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
  <PurchaseOrder>
    <ExternalId>918517</ExternalId>
    <Number>106001</Number>
    <PostingDate>2023-04-08T00:00:00</PostingDate>
    <VendorId>1f99d7da-549e-ed11-988a-000d3a3885d3</VendorId>
    <VendorNumber>V00010</VendorNumber>
    <Vendor>
      <Number>V00010</Number>
    </Vendor>
    <PayToVendorId>1f99d7da-549e-ed11-988a-000d3a3885d3</PayToVendorId>
    <PayToVendorNumber>V00010</PayToVendorNumber>
    <ShipToName>Zynk Software</ShipToName>
    <ShipToContact>Zynk Software</ShipToContact>
    <ShipToAddressLine1>6 Charlotte Square</ShipToAddressLine1>
    <ShipToAddressLine2></ShipToAddressLine2>
    <ShipToCity>Newcastle upon Type</ShipToCity>
    <ShipToCountry>GB</ShipToCountry>
    <ShipToState>Tyne &amp; Wear</ShipToState>
    <ShipToPostCode>NE1 4XF</ShipToPostCode>
    <BuyFromAddressLine1>6 Charlotte Square</BuyFromAddressLine1>
    <BuyFromAddressLine2 />
    <BuyFromCity>Newcastle upon Type</BuyFromCity>
    <BuyFromCountry>GB</BuyFromCountry>
    <BuyFromState>Tyne &amp; Wear</BuyFromState>
    <BuyFromPostCode>NE1 4XF</BuyFromPostCode>
    <CurrencyId>00000000-0000-0000-0000-000000000000</CurrencyId>
    <CurrencyCode>GBP</CurrencyCode>
    <DiscountAmount>0</DiscountAmount>
    <OrderDate>2023-03-07T00:00:00</OrderDate>
    <PaymentTermsId>0298d7da-549e-ed11-988a-000d3a3885d3</PaymentTermsId>
    <PaymentTerm>
      <Code>CM</Code>
    </PaymentTerm>
    <ShipmentMethodId>00000000-0000-0000-0000-000000000000</ShipmentMethodId>
    <ShipmentMethod>
        <Code>DELIVERY</Code>
    </ShipmentMethod>
    <Purchaser>JO</Purchaser>
    <RequestedReceiptDate>2023-04-01T00:00:00</RequestedReceiptDate>
    <FullyReceived>true</FullyReceived>
    <DimensionSetLines>
      <DimensionSetLine>
        <Code>AREA</Code>
        <ValueCode>40</ValueCode>
      </DimensionSetLine>
    </DimensionSetLines>
    <PurchaseOrderLines>
      <PurchaseOrderLine>
        <Id>95f1a3ff-549e-ed11-988a-000d3a3885d3</Id>
        <Sequence>10000</Sequence>
        <ItemId>2499d7da-549e-ed11-988a-000d3a3885d3</ItemId>
        <Item>
          <Number>1896-S</Number>
          <DisplayName>ATHENS Desk</DisplayName>
        </Item>
        <AccountId>00000000-0000-0000-0000-000000000000</AccountId>
        <Account>
          <Number>10000</Number>
        </Account>
        <LineType>Item</LineType>
        <LineObjectNumber>1896-S</LineObjectNumber>
        <Description>ATHENS Desk</Description>
        <UnitOfMeasureId>2d8c3bdf-549e-ed11-988a-000d3a3885d3</UnitOfMeasureId>
        <UnitOfMeasureCode>PCS</UnitOfMeasureCode>
        <Quantity>7</Quantity>
        <DirectUnitCost>100</DirectUnitCost>
        <DiscountAmount>0</DiscountAmount>
        <DiscountPercent>0</DiscountPercent>
        <TaxCode>STANDARD</TaxCode>
        <ItemVariantId>00000000-0000-0000-0000-000000000000</ItemVariantId>
        <ExpectedReceiptDate>2023-04-01T00:00:00</ExpectedReceiptDate>
        <InvoiceQuantity>0</InvoiceQuantity>
        <ReceiveQuantity>0</ReceiveQuantity>
        <DimensionSetLines>
          <DimensionSetLine>
            <Code>AREA</Code>
            <ValueCode>40</ValueCode>
          </DimensionSetLine>
        </DimensionSetLines>
      </PurchaseOrderLine>
    </PurchaseOrderLines>
  </PurchaseOrder>
</PurchaseOrders>