AXForum  
Вернуться   AXForum > Microsoft Dynamics AX > DAX Blogs
All
Забыли пароль?
Зарегистрироваться Правила Справка Пользователи Сообщения за день Поиск

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 13.05.2007, 17:12   #1  
Blog bot is offline
Blog bot
Участник
 
25,626 / 848 (80) +++++++
Регистрация: 28.10.2006
casperkamal: Using ADO to read from Excel in Microsoft Dynamics Ax
Источник: http://casperkamal.spaces.live.com/B...CD63!288.entry
==============

 
 
        Sometime back i had a posting referring to Gloomies blog (click to see the old posting) on using ADO in Ax. Gloomie had  used COM based ADO control. Ax also has  predefined ADO Com classes which  you can use....
 
  Here's a small Job that will help you in working with the Inbuild ADO classes
 
static void JobADOtoAccessExcelInAxapta(Args _args)
{
    CCADOConnection  adoexcel     = new CCADOConnection();
    CCAdoxCatalog    adoCatalog   = new CCAdoxCatalog();
    COM              adoxCatalog  = new COM('ADOX.Catalog');
    CCADORecordSet   adoRecordSet = new CCADORecordSet();
    CCADOFields      adoFields;
    CCADOField       adoField;
    int               i;
    ;

    adoexcel.connectionString("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=  
    C:\TestAdo.xls  ;Extended Properties='Excel 8.0;HDR=Yes;IMEX=1'");
    adoexcel.open();
    adoxCatalog.activeConnection(adoexcel.connection());
    adoCatalog.adoxCatalog(adoxCatalog);
    print adoCatalog.tableName(1);
    pause;
    adoRecordSet.open(@"SELECT * FROM [SHEET1$]", adoexcel);
    adoFields = adoRecordSet.fields();

    for (i = 0; i < adoFields.count(); i++)
    {
        adoField = adoFields.itemIdx(i);
        print adoField.name();
        pause;
    }

    while (! adoRecordSet.EOF())
    {
        for (i = 0; i < adoFields.count(); i++)
        {
            adoField = adoFields.itemIdx(i);
            print adoField.value();
            pause;
        }

        adoRecordSet.moveNext();
    }

}
 
 
Here is a snap shot of the excel that i used for the job....
 

 
 
.................. Keep watching while I post more on this ...



Источник: http://casperkamal.spaces.live.com/B...CD63!288.entry
__________________
Расскажите о новых и интересных блогах по Microsoft Dynamics, напишите личное сообщение администратору.
Старый 14.05.2007, 11:53   #2  
konopello is offline
konopello
SAP
SAP
 
628 / 76 (4) ++++
Регистрация: 08.11.2005
Адрес: Минск
Вот меня всегда интересовал вопрос как правельно наложить фильтр на запрос
X++:
adoRecordSet.open(@"SELECT * FROM [SHEET1$]", adoexcel);
например по полю name=konopello или city=Minsk
Старый 14.05.2007, 11:59   #3  
kashperuk is offline
kashperuk
Участник
Аватар для kashperuk
MCBMSS
Соотечественники
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,361 / 2084 (78) +++++++++
Регистрация: 30.05.2004
Адрес: Atlanta, GA, USA
Вырезка кода из Jobs (тестовых) проекта Gustav - ImportFromOfficeDB

X++:
    // cool real SQL-query to Excel sheet !!! have you ever dreamt about it ?!
    doc.setRecordSource(
        'SELECT * FROM [EmplTable$] WHERE Left([Name],1) IN             ' +
        '(                                                              ' +
        ' SELECT TOP 1 FirstLetter FROM                                 ' +
        '  (                                                            ' +
        '   SELECT TOP 3 FirstLetter, Count(*) AS CountOfFirstLetter    ' +
        '   FROM                                                        ' +
        '    (                                                          ' +
        '     SELECT Left([Name],1) AS FirstLetter, [EmplTable$].*      ' +
        '     FROM [EmplTable$]                                         ' +
        '    )                                                          ' +
        '   GROUP BY FirstLetter                                        ' +
        '   ORDER BY Count(*) DESC                                      ' +
        '  )                                                            ' +
        ' ORDER BY CountOfFirstLetter                                   ' +
        ')                                                              ' );
    // this query returns subset of records from worksheet EmplTable,
    //   in which every name of employee starts with character,
    //      which is on 3rd position in rank of more popular first characters in Name field (Oh Mein Got! :-))
 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Dynamics AX: Managing Your Supply Chain Using Microsoft Dynamics AX 2009 - Book Review Blog bot DAX Blogs 0 31.03.2009 23:06
Dynamics AX: Microsoft's strategy and vision for Dynamics AX and SOA Blog bot DAX Blogs 0 05.03.2009 18:05
axStart: Microsoft Dynamics AX 2009 Hot Topics Web Seminar Series Blog bot DAX Blogs 0 06.08.2008 12:05
Dynamics AX: Interview with Microsoft Dynamics Executives Blog bot DAX Blogs 0 31.05.2008 00:10
Сергей Герасимов: Что нового в Microsoft Dynamics AX 4.0 Blog bot DAX Blogs 0 16.01.2007 11:00

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 16:48.