4

我想知道如何使用 C#(.Net Business Connector)从 AX 调用内核函数。

具体来说,你可以调用fieldName2Id、tableName2Id和curUserId之类的方法吗?

4

2 回答 2

10

我找到了一些调用内核函数的解决方法:

表名2Id

(我本来是想tablenum办法的):


   //I used an extension method here  
   public static int GetTableId(this Axapta ax, string tableName)  
   {  
       return (int)ax.CallStaticClassMethod("Global", "tableName2Id", tableName);  
   }


curUserId


    //Another extension method  
    public static string CurUserId(this Axapta ax)  
    {  
        return (ax.CallStaticClassMethod("xUserInfo", "find") as AxaptaRecord).get_Field("Id").ToString();  
    }  


字段名称2Id

(我本来是想fieldnum办法的)


    //Another extension method  
    public static int GetFieldId(this Axapta ax, string tableName, string fieldName)  
    {  
        AxaptaObject dictionary = ax.CreateAxaptaObject("Dictionary");  
        int fieldId = 0;  
        if (ax.TableExists(tableName))  
        {  
            int tableId = ax.GetTableId(tableName);  
            AxaptaObject dictTable = (AxaptaObject)dictionary.Call("tableObject", tableId);  
            fieldId = (int)dictTable.Call("fieldName2Id", fieldName);  
        }  
        return fieldId;  
    }  

我希望这对其他人有帮助!

于 2010-05-20T15:48:43.557 回答
0

最好使用:

Dictionary  dictionary = new Dictionary();
;
dictionary.tableName2Id(...);
于 2018-08-16T09:00:50.603 回答