我想知道如何使用 C#(.Net Business Connector)从 AX 调用内核函数。
具体来说,你可以调用fieldName2Id、tableName2Id和curUserId之类的方法吗?
我想知道如何使用 C#(.Net Business Connector)从 AX 调用内核函数。
具体来说,你可以调用fieldName2Id、tableName2Id和curUserId之类的方法吗?
我找到了一些调用内核函数的解决方法:
(我本来是想tablenum
办法的):
//I used an extension method here
public static int GetTableId(this Axapta ax, string tableName)
{
return (int)ax.CallStaticClassMethod("Global", "tableName2Id", tableName);
}
//Another extension method
public static string CurUserId(this Axapta ax)
{
return (ax.CallStaticClassMethod("xUserInfo", "find") as AxaptaRecord).get_Field("Id").ToString();
}
(我本来是想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;
}
我希望这对其他人有帮助!
最好使用:
Dictionary dictionary = new Dictionary();
;
dictionary.tableName2Id(...);