Tuesday, 20 June 2017

Import the data from Excel to D365/Ax7

using System.IO;
using OfficeOpenXml;
using OfficeOpenXml.ExcelPackage;
using OfficeOpenXml.ExcelRange;

class RunnableClass1
{      
    /// <summary>
    /// Runs the class with the specified arguments.
    /// </summary>
    /// <param name = "_args">The specified arguments.</param>
    public static void main(Args _args)
    {  
        System.IO.Stream            stream;
        ExcelSpreadsheetName        sheeet;
        FileUploadBuild             fileUpload;
        DialogGroup                 dlgUploadGroup;
        FileUploadBuild             fileUploadBuild;
        FormBuildControl            formBuildControl;
        TableTest                          test;
        Dialog                      dialog = new Dialog("Import the data from Excel");

        dlgUploadGroup          = dialog.addGroup("@SYS54759");
        formBuildControl        = dialog.formBuildDesign().control(dlgUploadGroup.name());
        fileUploadBuild         = formBuildControl.addControlEx(classstr(FileUpload), 'Upload');
        fileUploadBuild.style(FileUploadStyle::MinimalWithFilename);

        fileUploadBuild.fileTypesAccepted('.xlsx');

        if (dialog.run() && dialog.closedOk())

        {
            FileUpload fileUploadControl     = dialog.formRun().control(dialog.formRun().controlId('Upload'));

            FileUploadTemporaryStorageResult fileUploadResult = fileUploadControl.getFileUploadResult();

            if (fileUploadResult != null && fileUploadResult.getUploadStatus())

            {

                stream = fileUploadResult.openResult();

                using (ExcelPackage Package = new ExcelPackage(stream))

                {

                      int                         rowCount, i;
                   
                      Package.Load(stream);
                   
                      ExcelWorksheet  worksheet   = package.get_Workbook().get_Worksheets().get_Item(1);
                   
                      OfficeOpenXml.ExcelRange    range       = worksheet.Cells;
                   
                      rowCount                  = (worksheet.Dimension.End.Row) - (worksheet.Dimension.Start.Row) + 1;
                    //rowCount = 1;
                    //i=Range.Rows;

                    for (i = 2; i<= rowCount; i++)

                    {

                        test.AccountNum = range.get_Item(i, 1).value;

                        test.AccountName = range.get_Item(i, 2).value;
                        test.insert();

                    }

                }

            }

            else

            {

                error("Error ");

            }
            info("Done");

        }

       

    }

}

Friday, 16 June 2017

Design Permissions for Fields in a Table

You can use the AOT to design permissions for the fields in a table. By changing the EffectiveAccess property in permissions for each of the fields you can control the application user access to those fields. For example, you can control whether the application user can view or edit some of the fields on a form based on the security role assigned to the application user.

Prerequisites

To understand this walkthrough topic, you first need to understand the following areas:

Preliminary Environment

This topic assumes that several AOT items already exist, or that you can imagine them. The items are as follows:
  • Table – Person table, with fields CityName, and Zip.
  • Form – FieldsForm form.
  • Data source – Person table as the data source for FieldsForm form.
  • Menu – Home > Common menu, which might already exist.
  • Menu Item – FieldsMenuItem menu item, with its ObjectType property set to Form, and its Object property set to FieldsForm.
  • Security > Privilege – TestFieldPrivilege privilege.
  • Privilege > TestFieldPrivilege > Entry Point – FieldsMenuItem, with its ObjectType property set to MenuItemDisplay.
    You can test with different values for the AccessLevel property, but start with Update.
The following image displays a project that contains almost everything in the preceding list. In the next section you create the node AOT > Security > Privileges > Permissions > Tables > Person, and the field nodes under it.
AOTSecurityFieldsPermProject
The project that you create

Create Field Permissions

You can create field permissions for TestFieldPrivilege by following these steps:

  1. Add the Person table to the TestFieldPrivilege privilege. Do this by dragging the node
     AOT > Data Dictionary > Tables > Person
    onto the node at
     AOT > Security > Privileges > TestFormPrivilege > Permissions > Tables.
    TipTip
    Drag operations are easier when you have two AOT windows open. You can drag from one AOT to the other.
  2. On the new Person node, set the EffectiveAccess property to Update.
  3. At Data Dictionary > Tables > Person > Fields, highlight all fields and drag them onto the TestFieldPrivilege > Permissions > Tables > Person node.
  4. Set the EffectiveAccess property for each new field node as follows:
    • City – Update
    • Name – Read
    • Zip – NoAccess

Tuesday, 30 May 2017

SSRS Report AX 2012 - The operation has timed out error message when you run a report in Microsoft Dynamics AX

About this problem, read below and test to find if this will have improved SSRS Report performance:

There is a process to change long running jobs so that they are run in a Pre-Processing way, so that all the data is prepared before the SSRS Report Window is started. This prevents the timeout problem, sometimes shown by the message ““A connection attempt failed because the connected party did not properly respond after a period of time, or established connection failed because connected host has failed to respond”

To change the report to run in these pre-processing way ( Similar Sales confirmation, Sales Invoice, etc. reports ), see this example below for the Dimension Statement report on how to change this:



1.    To find which object you need to modify, first look in the AOT > Menus, for the Menu where the report is

2.    View the properties on this to see the associated menu item. You can see below the menu item is “LedgerDimensionTransStatement”.

3.    Find this menu item in AOT > Menu Items > Output

…and look at the properties, make a note of the “LinkedPermissionObject”, in this case “LedgerTransStatement”

4.    Next in the AOT > SSRS Reports > Reports, locate LedgerTransStatement, then expand this out until you see the Server Methods. Make a note of the Server Method class, in this case “LedgerTransStatementDP”

5.    In the AOT > Classes, locate and open class LedgerTransStatementDP.

6.    In the LedgerTransStatementDP\classDeclaration, change line 9 to extend SrsReportDataProviderPreProcess instead of SrsReportDataProviderBase

7.    Make a note of the Temp table used in the report, as above this is LedgerTransStatementTmp.

8.    Next, change the method LedgerTransStatementDP\processReport to add the following line after the contract (line 27):



ledgerTransStatementTmp.setConnection(this.parmUserConnection());


9.    Next, in AOT > Data Dictionary > Tables, locate the table you made a note of in point 7, so in this case the LedgerTransStatementTmp. Change the table properties as follows:



·         TableType = Regular

·         CreatedBy = Yes

·         CreatedTransactionId = Yes



10. Opened LedgerTransStatement.Detail report in Visual Studio and refreshed the data source to include new field (CreatedTransactionId).

11. Deployed the new LedgerTransStatement.Detail report.

12. In AX, did a Generate Incremental CIL.

13. Restart SSRS


Also, at this link

Microsoft Dynamics AX 2012 Reporting: How to run reports that executes longer than 10 minutes

The operation has timed out" error message when you run a report in Microsoft Dynamics AX 2012

AX 2012: Report timeout error

How To: Addressing SSRS Session Timeouts

you can find useful information about modify the SQL Reporting Send Timeout Parameter.

http://sinedax.blogspot.in/2012/11/ssrs-report-ax-2012-operation-has-timed.html

Sunday, 7 May 2017

Inserting Space between the characters in a String in Ax


Hi,

Today I would like to share you x++ code to insert space between the characters in a string in AX.

Example 1:

static void insertSpaceBtwString(Args _args)

{

str s,s1;

int i,j;

s="KORCOMPTENZ";

j= strLen(s);

for(i=1;i<=j;i++)

{

   s1=s1+subStr(s,i,1);

  if(i!=strLen(s))

  s1=s1+ " ";

}

info(s1);

}

Output:
Example 2:
Inserting space after each four digit Number

static void InsertSpace(Args _args)

{

str s,s1;

int i,j;

s="1245678945612355";

j= strLen(s);

for(i=1;i<=j;i=i+4)

{

    s1=s1+subStr(s,i,4);

    if(i+4<=j)

    s1=s1+" ";

}

info(s1);

}

Output:

Happy Daxing....

Tuesday, 4 April 2017

Publishing AX Reports – User or group name not recognized

You may encounter an issue with trying to release reports to your AX environment when you move databases between environments. The error you might receive, during the report release, is Publish_AXReport: The user or group name ‘xxx’ is not recognized


Even though everything is setup correctly in your AX environment, the error is caused by having additional records in the table SysServerSessions. If from SQL you review the data in this table you should notice that you have records that point to old servers/instances. You need to delete all the records that are not relevant to your current environment. Once done you should be able to deploy reports with getting the user or group name error.

Wednesday, 15 March 2017

Server backup




How to schedule a SQL Server backup


Having a good backup and restore plan is an important part of a disaster recovery strategy. This article will describe 3 different solutions/approaches for creating a scheduled backup in SQL Server
As a part of a backup strategy several types of backup can be used together.

Backup types

  1. Full database backups include all database objects, system tables, data, and transactions that occur during the backup. Full database backups allow performing a complete restoration to a state before the backup is performed.
  2. Differential backups contain data that has changed since the last full backup was performed and transactions that occur during the backup process. A differential backup is used alongside with the last full database backup. After taking a differential backup, as it is taken after the last full backup all of the old differential backups become obsolete.
  3. Transaction log backups records all the transactions that have occurred on a database since the previous transaction log backup and then truncates the transaction log and then truncates a transaction log. A transaction log backup ensures database recovery to a specific point of time e.g. to a moment prior to data loss.
  4. File and filegroup backups option is most suitable for backing up very large databases. A file backup will contain all the data in one or more files or filegroups. A transaction log backup has also be performed to span all the file backups from start to finish when using file backups to restore a database.
  5. Copy-only backups are mostly used when it’s needed to backup a database without affecting the processes of backup and restore for a specific database. Functionality of a copy-only backup is the same as full database with a difference that a transaction log backup will backup all transactions since the last full backup is performed and ignore the existence of the copy backup, therefore a copy backup cannot be used as the basis for differential and transaction log backups.

Recommended backup strategy practices

Backup location

It is advisable that backups are not stored on the same location (physical drive) where database files are stored. In cases when a physical drive fails use the drive or a network location to perform restore. If a file location is not specified when creating a database SQL Server will store database files on the default database locations.
Note that changing the default locations won’t move the current data and log files to a new location. This will only be applicable to databases created after this change.

Scheduled and automated backups

To prevent and backup safety and reliability is to set up (automate) the backup process through the means of schedules. Creating backup schedules is important as the time passes current backups get obsolete and out of time.
Keep yourself protected and be sure that you always have at hand a way to reestablish your data up until the point where the database failed. Scheduled backups provide an accurate data history.
The specified frequency of a backup depends on the company business needs etc., and is defined by Recovery Point Objective (RPO). For example, if an organization’s Service Level Agreement (SLA) specifies that no more than an hour’s data can be lost from a database, the RPO is one hour.

Test backups

Backup and recovery strategy cannot be complete until backups are successfully restored on a test server and verified that backup can be restored to fulfill all the requirements and conditions including all the combinations that the recovery strategy requires. There is a variety of factors to consider such as: the organizations requirements regarding the usage of data, protection etc.

Backup verification

Verifying backup ensures that a backup is created correctly, intact physically, that all the files in the backup are readable and can be restored in the event that the user needs to use it, and that all the transactions are consistent. It is important to understand that verifying a backup does not verify the structure of the data on the backup. However, if the backup was created using WITH CHECKSUMS, verifying the backup using WITH CHECKSUMS can provide a good indication of the reliability of the data on the backup.
By using T-SQL:
Including the CHECKSUM statement ensures consistency of data on the backup destination. To include CHECKSUM use the following query:
BACKUP DATABASE [AdventureWorks2012]
TO  DISK = N'F:\Backup\AW12.bak'
WITH CHECKSUM;
SQL Server Management Studio also provides options to include backup verification a CHECKSUM check when creating a backup as a task:
The Verify backup when finished option and Perform checksum before writing to media are used as an insurance that both backup and its data are consistent.
We will also show how to include verifications when scheduling backups.
In this article we will create a SQL Server scheduled backup by using a SQL Server Agent job, SQL Server Maintenance Plans, and ApexSQL Backup.

Create a SQL Server scheduled backup by using a SQL Server Agent job

To automate and schedule a backup with SQL Server Agent:
  1. In the Object Explorer pane, under the SQL Server Agent node, right click Jobs and select New job from the context menu:
  2. In the New Job dialog enter a job’s name
  3. Under the Steps tab click on the New button and create a backup step by inserting a T-SQL statement. In this case the CHECKSUM clause has to be included in T-SQL code:
    USE AdventureWorks2012
    GO
    BACKUP DATABASE [AdventureWorks2012]
    TO  DISK = N'F:\Backup\AW12.bak'
    WITH CHECKSUM;
    
    To create a differential backup use the following T-SQL script:
    USE AdventureWorks2012
    GO
    BACKUP DATABASE [AdventureWorks2012]
    TO  DISK = N'F:\Backup\AW12.bak'
    WITH CHECKSUM;
    
    
    BACKUP DATABASE [AdventureWorks2012]
       TO  DISK = N'F:\Backup\AWD12.bak'
       WITH DIFFERENTIAL;
       WITH CHECKSUM;
    
    GO
    
    To backup transaction log use the following script:
    BACKUP LOG [AdventureWorks2012]
       TO  DISK = N'F:\Logs\AWD12.log';
    GO
    
    Note: To create a differential or a transaction log SQL Server database backup a full database backup has to exist. If a desired database has never been backed up, before creating differential backups, first create a full database backup. Differential and transaction log backups can be used along a full database backup. For example, a full backup can be scheduled every 24 hours, a differential backup can be performed every 5 hours, and a transaction log backup every 15 minutes.
  4. Click ok to add a step, and click OK to create a job:
  5. To schedule a job, in the New Job dialog, under the Schedule tab click New.
  6. In the Job Schedule select an occurring frequency and a start date and click OK:
To check a created job in the Object Explorer pane and under the SQL Server Agent ➜ Jobs node right click the job create above and select the Start job at step option:
To use SQL Server Agent for backing up all databases under one instance there are two approaches, both of which require some manual work. One approach is to create a SSIS package using the Backup Database Task option from the SSIS toolbar and create a SQL Server Agent job to schedule it.
The other approach is to write a T-SQL script to backup all databases in the SQL Server Agent Job Step dialog.

Create a SQL Server scheduled backup by using SQL Server Maintenance Plans

There are two options to create a scheduled backup task by using SQL Server Maintenance Plans: manually by creating a new plan and by using the Maintenance Plan Wizard.
To manually create a scheduled backup task:
  1. In the Object Explorer pane under the Management node right click Maintenance Plans and select the New Maintenance Plan option:
  2. From the Maintenance Plan Tasks toolbox select Back Up Database Task:
    The Maintenance Plan Wizard also provides the Check database integrity task that can be included in Maintenance Plan:
  3. Double click on an added plan and set backup options:
  4. To schedule a SQL Server Agent job use the Sub plan scheduling option.
  5. When a plan is created click save and this action will create a corresponding job under the SQL Server Agent ➜ Jobs folder.
A method to create a new maintenance plan through the Maintenance Plan Wizard guides the user through the process, but this option provides fewer options for fine tuning.
To automate and schedule a backup by using the SQL Server Maintenance Plan Wizard:
  1. In the Object Explorer pane under the Management node right click Maintenance Plans and select the Maintenance Plan Wizard option:
  2. In the Select Plan Properties window specify a plan name. To schedule a SQL Server Agent job click the Change button:
  3. In the Select Maintenance Plan Tasks select the Back Up Database option and the Check data integrity option. The check data integrity tack performs internal consistency check of the data and index pages within the database :
  4. In the following window configure the maintenance task by specifying a database for backup and the backup options. In the Define Back Up Database Task window also check the Verify backup integrity option:
  5. After verifying the choices and actions click Finish:
Maintenance Plans are more suitable for less experienced DBAs because they provide an easy to use GUI, and do not require manually written maintenance scripts. The downside of Maintenance Plans is that the tasks that Maintenance Plans provide are basic and don’t leave space for customization.
A Maintenance Plan is also atomic and is therefore not able to run multiple tasks. Each type of maintenance task within a single Maintenance Plan can only be configured to run once within that Plan. For example, if a task that is made to delete older backup files it will only delete one file type at a time. Because of this multiple Maintenance Plans have to be created just to perform a single task, in some cases, and every Maintenance Plan has to have a corresponding SQL Server Agent job to be scheduled.

Create a SQL Server scheduled backup by using ApexSQL Backup

As we saw when scheduling a SQL Server backup as a SQL Server Agent job we have to write a T-SQL script. Also, to fulfil the organizations SLA we would have to make two more jobs, one for a differential and one for a transaction log job.
To save time from having to write T-SQL scripts and eliminate the need to maintain both back up plans and their corresponding jobs when using SQL Server Maintenance Plans, a 3rd party tool, ApexSQL Backup, can be used.
ApexSQL Backup is a SQL Server backup manager that enables automating and scheduling SQL Server backup jobs in one task while preserving the backup chain for easy point-in-time restoration (database rollback).ApexSQL Backup is also able to run multiple tasks at the same time and provides an out of the box solution for scheduling a database backup for one or all databases in just a few clicks.
To create a SQL Server scheduled backup in ApexSQL Backup:
  1. In the Home tab of the main menu select the Backup option:
  2. In the Backup wizard specify a server name, a database name, and a backup type. ApexSQL Backup supports all backup types and provides an option to select all databases:
  3. In the Type and output window specify a destination folder and an output name:
  4. In the Options window specify backup options such as backup verification, compression, encryption etc. ApexSQL Backup offers options to include both the Verify backup step when finished, and the Perform checksum step before writing to media option during the process of creating a backup task without the need for writing a separate script:
  5. In the following window select the Schedule option and specify the occurring frequency. ApexSQL Backup allows scheduling a backup task during the process of creating a task:
  6. Submit a scheduled backup.
Here’s a review of all three approaches to schedule a database backups:
SQL Server Agent
Maintenance Plans
ApexSQL Backup
T-SQL script needed
Yes
No
No
Can backup all databases without a script
No
Yes
Yes
Can execute a task without an additional job
Yes
No
Yes
Can run multiple tasks at once
No
No
Yes
Useful resources:

Export Data from AX 2012 - using DIXF (Data Migration Framework)

Importing is a well known task using DIXF, but at times we do need to export as well and then import it back in AX 2012. The export task can be done with the help of this information.

https://technet.microsoft.com/en-us/library/dn144987.aspx



Define the format of your source data


  1. Open Data Import/Export Framework > Setup > Source data formats.
  2. Click New, enter a name and a description, and then select AX from the Type list.

Define a processing group to export data from Microsoft Dynamics AX


  1. Change the company to CEU.
  2. In Data Import/Export Framework, click Common > Processing group, and then click New to create a new processing group.
  3. Set the group name to Export-Cust and add a description.
  4. Click Entities to select the entities to include in the processing group.
    1. In the Select entities for processing group form, click New, and then, for an entity name, select Customer.
    2. In the Source data format field, select the Microsoft Dynamics AX source data format that you created.
    3. Click the Select button, and then in the DMFCustomerTargetEntity form, on the Range tab, for Field, choose Created date and time, and for Criteria, enter > 9/1/2007, and then click OK.
    4. Close the Select entities for processing group form.

Process data from source to staging


  1. In the Processing group form, select the Export-Cust group that you created, and click Get staging data.
    The Create a job ID for the staging data job form opens.
  2. By default, an ID for the job is generated. If needed, you can modify the ID and add a description. Click OK.
    The Staging data execution form opens.
  3. In the Staging data execution form, click Run.
    The Get data from source to staging form opens.
  4. In the Get data from source to staging form, click OK to run immediately.
    The source data is copied to the staging tables.

Validate the data in staging


  1. In Data Import/Export Framework, click > Common > Processing group > Execution history, and then select the job that ran.
  2. Click View staging data.
  3. Review the staging data to validate that it matches the source.
  4. Click Validate all to verify that all the related reference data is correct and present in the system.

Export the data to a file


  1. In , click > Common > Processing group, and then select the processing group to work with.
  2. Click Export to AX, enter a file name, and then click OK.
    A .dat file of the data identified by the processing group is created.