2015-05-06 60 views

回答

4

我想你必須使用AxaptaContainer類來傳遞容器中的值。

AxaptaRecord axRecord; 

try 
{ 
    // Login to Microsoft Dynamics AX. 
    ax = new Axapta(); 
    ax.Logon(null, null, null, null); 

    // Create a new AddressState table record. 
    using (axRecord = ax.CreateAxaptaRecord("TableName")) 
    { 
     // Provide container for record field. 
     AxaptaContainer axContainer = ax.CreateAxaptaContainer(); 
     axContainer.Add("Some Data"); 

     axRecord.set_Field("ContainerField", axContainer); 

     // Other fields 

     // Commit the record to the database. 
     axRecord.Insert(); 
    } 
} 
catch (Exception e) 
{ 
    Console.WriteLine("Error encountered: {0}", e.Message); 
    // Take other error action as needed. 
} 

我還沒有測試過,所以請提供一些反饋意見,以便我們改進解決方案。

+0

Thanks Maxim, 容器是正確的選擇。 正確初始化AxaptaContainer的方法是在Axapta類中調用CreateAxaptaContainer方法。 –

+0

您能否提供一些示例代碼,以便我可以更新答案以供將來參考? –

+0

我會發布完整的代碼最大。 –

2
 Axapta DynAx = new Axapta(); 
     AxaptaRecord DynRec; 
     string strUserName = ""; 
     System.Net.NetworkCredential nc = new System.Net.NetworkCredential("", ""); 

     string tableName = ""; 

     DynAx.LogonAs(strUserName.Trim(), "", nc, dataAreaId, "en-us","", ""); 

     try 
     { 
      using (DynRec = DynAx.CreateAxaptaRecord(tableName)) 
      { 
       var binData = DynAx.CreateAxaptaObject("Bindata"); 
       var loaded = binData.Call("loadFile", path); 
       var data = binData.Call("getData"); 

       AxaptaContainer axc = DynAx.CreateAxaptaContainer(); 

       axc.Add(data); 


       DynRec.set_Field("ATTACHMENT", axc.get_Item(1)); 

       // Commit the record to the database. 
       DynRec.Insert(); 
      } 
     } 
     catch (Exception ex) 
     { 
      return false; 
     } 
     finally 
     { 
      DynAx.Logoff(); 
     } 

對Ax進行身份驗證,從Axe Bindata類中獲取容器並保存記錄。

相關問題