Извлечение данных из Dynamics Axe 2009 с использованием веб-сервисов Axe и C # - PullRequest
1 голос
/ 12 января 2011

Я пытаюсь получить список поставщиков из базы данных AX.

Я хочу показать список поставщиков на моей странице aspx. Как я могу добиться этого?

здесьчто я сделал до сих пор

1-Развертывание веб-сервисов Axe.2-Создан клиентский класс для вызова службы.

Я застрял здесь и не уверен, как получить данные.

Пожалуйста, совет.

Ответы [ 2 ]

2 голосов
/ 13 января 2011

Я узнал, как это сделать. Вот решение о том, как использовать веб-сервисы AIF. Вот код. Пожалуйста, обратитесь к следующей статье http://msdn.microsoft.com/en-us/library/cc652581.aspx

        customerService.CustomerServiceClient sc = new ConsumingAxWebService.customerService.CustomerServiceClient();

         AxdCustomer axdCustomer;

        QueryCriteria queryCriteria;
        CriteriaElement[] criteriaElements;
        IEnumerator enumerator;
        int iCountLoops1 = 0;
        AxdEntity_CustTable cust;


        criteriaElements = new CriteriaElement[1];
        criteriaElements[0] = new CriteriaElement();

        criteriaElements[0].DataSourceName = "CustTable";
        criteriaElements[0].FieldName = "AccountNum";
        criteriaElements[0].Operator = Operator.Range;
        criteriaElements[0].Value1 = "1101";
        criteriaElements[0].Value2 = "1102";


        queryCriteria = new QueryCriteria();
        queryCriteria.CriteriaElement = criteriaElements;
        axdCustomer = sc.find(queryCriteria);

        enumerator = axdCustomer.CustTable.GetEnumerator();

        while (enumerator.MoveNext())
        {
            ++iCountLoops1;
            cust = (AxdEntity_CustTable)enumerator.Current;
            Response.Write(cust.AccountNum + "\n");
        }
0 голосов
/ 16 ноября 2011

Поскольку даты и я могу перемещать десятичные дроби в веб-службу в Ax, название службы, которую я использую, - CustFreeTextInvoice.

Передача строковых данных не проблема, но с датой и самими десятичными данными.

код прикреплен ...

private void btnIngresar_Click(object sender, EventArgs e)
    {
        FreeTextInvoiceServiceClient service = new FreeTextInvoiceServiceClient();

        if (null == service)
        {
            throw new Exception("Cannot instantiate service.");
        }

        AxdFreeTextInvoice FreeTextInvoice = new AxdFreeTextInvoice();

        //Record
        AxdEntity_CustInvoiceTable CustInvoiceTable = new AxdEntity_CustInvoiceTable();
        CustInvoiceTable.InvoiceId = "100";
        CustInvoiceTable.Name = txtName.Text;
        CustInvoiceTable.OneTimeCustomer = 0;
        CustInvoiceTable.OrderAccount = txtOrderAccount.Text;
        //CustInvoiceTable.DocumentDate = DateTime.Now;
        //CustInvoiceTable.DueDate = Convert.ToDateTime("20/12/2011");
        CustInvoiceTable.InvoiceDate = Convert.ToDateTime("20/11/2011");

        CustInvoiceTable.CustInvoiceLine = new AxdEntity_CustInvoiceLine[2];

        CustInvoiceTable.CustInvoiceLine[0] = new AxdEntity_CustInvoiceLine();
        CustInvoiceTable.CustInvoiceLine[0].Description = "Primer registro";
        CustInvoiceTable.CustInvoiceLine[0].LedgerAccount = "610208";
        CustInvoiceTable.CustInvoiceLine[0].TaxGroup = "IVAVTAS12";
        CustInvoiceTable.CustInvoiceLine[0].TaxItemGroup = "all";
        CustInvoiceTable.CustInvoiceLine[0].AmountCur = 1000;

        CustInvoiceTable.CustInvoiceLine[1] = new AxdEntity_CustInvoiceLine();
        CustInvoiceTable.CustInvoiceLine[1].Description = "segundo registro";
        CustInvoiceTable.CustInvoiceLine[1].LedgerAccount = "610208";
        CustInvoiceTable.CustInvoiceLine[1].TaxGroup = "IVAVTAS12";
        CustInvoiceTable.CustInvoiceLine[1].TaxItemGroup = "all";
        CustInvoiceTable.CustInvoiceLine[1].AmountCur = 90;

        FreeTextInvoice.CustInvoiceTable = new AxdEntity_CustInvoiceTable[1] { CustInvoiceTable };

       try
        {
            testws.FTIS.EntityKey[] returned = service.create(FreeTextInvoice);
            testws.FTIS.EntityKey returnedValues = (testws.FTIS.EntityKey)returned.GetValue(0);
            Console.WriteLine("Valor retornado: " + returnedValues.KeyData[0].Value);
            Console.ReadLine();

        }
        catch (Exception ex)
        {
            Console.WriteLine("Error: " + ex.ToString());
            Console.ReadLine();
        }
    }
...