印仔 发布的文章

Dynamic 365中创建编码规则与Dynamic Ax 2012 基本一致。以下几个步骤,就当温习一下吧。

1.创建扩展类型,将此字段添加到需要创建编码的表中。

2.在对应添加编码模块下的编码类中添加LoadModel,以下以库存管理模块为例:

[ExtensionOf(classstr(NumberSeqModuleInventory))]//扩展库存管理编码类
final class  NumberSeqModuleInventory_Extension
{
    protected void loadModule()
    {
        NumberSeqDatatype datatype = NumberSeqDatatype::construct();

        next loadModule();

        datatype.parmDatatypeId(extendedTypeNum(TestAccount));//要加编码字段对应的扩展类型
        datatype.parmReferenceHelp(literalStr("测试账号"));//扩张类型标签
        datatype.parmWizardIsContinuous(false);
        datatype.parmWizardIsManual(NoYes::No);
        datatype.parmWizardFetchAheadQty(10);
        datatype.parmWizardIsChangeDownAllowed(NoYes::No);
        datatype.parmWizardIsChangeUpAllowed(NoYes::No);
        datatype.parmWizardHighest(99999999);
        datatype.parmSortField(2006);
        datatype.addParameterType(NumberSeqParameterType::DataArea, true, false);
        this.create(datatype);
    }

}

3.生成编号逻辑(在对应模块下的参数表中新建静态方法)

[ExtensionOf(tableStr(InventParameters))]//扩展库存表
final class InventParameters_Extension
{

public server static NumberSequenceReference numTestAcount()
{
    return NumberSeqReference::findReference(extendedTypeNum(TestAccount));
}

}

4.在字段所在表调用生成编号规则(在需要生成的时候直接调用此方法即可,一般在表新建初始化时就调用了)

表中调用方法:

 public void initValue()

{
    NumberSeq  numberseq;
    super();
    //第三步可省略,将这句直接替换成:numberseq = NumberSeq::newGetNum(NumberSeqReference::findReference(extendedTypeNum(TestAccount)));
    numberseq = NumberSeq::newGetNum(InventParameters::numTestAcount());

    numberseq.used();
    this.SubtenancyAccount = numberseq.num();
}
  1. 运行Job加载Model(D365中,Jobbunen给直接运行,需要添加到按钮,放在界面,以此调用)

class LodNumberSeq
{

public static void main(Args _args)
{       
    NumberSeqApplicationModule::loadAll();
    info("Finished");
}

}

6.在前台界面配置生成规则:

路径:组织管理-编号规则,新建,选到对应模块和自己调价的名称进行自定义设置

这样,就可以测试啦!嘿嘿哈哈,good luck.

原文

D365

  • HcmWorkerLookup::currentWorker()
  • 调试时,允许断点在包外。
  • intvno()

     https://community.dynamics.com/365/financeandoperations/b/alirazatechblog/posts/dynamics-ax-2012-number-of-months-between-two-dates
  • Createby -> Hcmworker
    HcmWoker::userId2Worker();
  • FromRun DateSource
    https://blog.csdn.net/rocklee/article/details/81805731

*query dimension filter

https://www.cnblogs.com/dingkui/p/16708449.html
D365: 过滤DefaultDimension和LedgerDimension中的财务维度
  • Lookup

    sysTableLookup.parmUseLookupValue(false);
    

C#  

  • C# 泛型 逆变 协变
  • C# Delegate Action Func

网页

https://baidu.leeay.com/

.Net

路由规则

  • get 参数必选?

单例陷阱

EFCORE

https://zhuanlan.zhihu.com/p/161107452

跨域

ApiController

model

三种返回值

Obj,IActionResult,ActionResult

minimal API

路由约束,

数据验证

依赖注入,控制反转,

服务

注册服务

launch.json

Vue3

知识

Association Aggregation Composition 区别。

    Date                        endDate;
    FormDataSource              fds;
    MultiSelectionHelper        MultiSelectionHelper;
    AssetTable                  assetTable;
    AssetBookId                 bookId;
    AssetBook assetBook;
    IWS_FixedAssetCardContract  contract;
    Args                        argsLocal;
    ;       
    argsLocal= this.parmArgs();
    contract =this.parmReportContract().parmRdpContract() as IWS_FixedAssetCardContract;

    if( argsLocal.callerName() == "AssetTable") //is AssetTable)
    {
            
        fds = args.record().dataSource();
        multiSelectionHelper = MultiSelectionHelper::construct();
        multiSelectionHelper.parmDatasource(fds);
        assetTable = multiSelectionHelper.getFirst();

        select firstonly assetBook where assetBook.assetId == assetTable.assetId;
        bookId = assetBook.BookId;

        List list = new List(Types::String);
        while (assetTable)
        {
            list.addEnd(assetTable.assetId);
            assetTable = multiSelectionHelper.getNext();
        }
    

        contract.parmAssetList(list);
        contract.parmBookId(bookId);

MS-SQL Server
select * from Book where BookName like'%C语言%'
在SQL2000下能正常找到,在2005下不能,因为语句中的中文字体, 但是使用
select * from Book where BookName like N'%C语言%' ,这样就完合正常了,
Like 后的N是表示什么意思呢
unicode字符
N转换字符串为nchar,nvarchar
当把客户端发送的非 Unicode 数据以 Unicode 存储在服务器中时,如果具备下列条件之一,则来自任何客户端的任何代码页的数据都可以正确地存储
字符串常量以大写字母 N 开头。无论客户端应用程序是否能够识别 Unicode,必需这样做。如果没有字母 N 前缀,则 SQL Server 会将字符串转换为与数据库的默认排序规则相对应的代码页。此代码页中没有的字符都将丢失。

此外,对于非英文字符串查询也应该写成 ike N'...'

Copy from https://blog.csdn.net/miao0967020148/article/details/71108056

应开发如下几项:

1. 若有新实体则需要开发新实体类及生产类;
2. 获取审批列表方法中while循坏添加对应表的判断;
3. 获取审批列表方法中while循环case到对应表创建实体(多种状态都要);