Farseer

导航

D365 FO 扩展框架缓存

https://www.cnblogs.com/Farseer1215/p/12845342.html
这一篇文章中介绍了,通过属性扩展的框架。
最近遇到一个问题,不小心笔误了,比如如下所示,把Female的属性不小心写成male了,然后编译是不会报错的。

 1 [Gender(Gender::Male)]
 2 public class Person_Male extends Person
 3 {
 4     public str fromWhere()
 5     {
 6         return "Mars";
 7     }
 8 
 9 }
10 
11 [Gender(Gender::male)]
12 public class Person_Female extends Person
13 {
14     public str fromWhere()
15     {
16         return "Venus";
17     }
18 
19 }

运行时,实例化的时候,会报下面的错误。

 这个很好理解,因为一个属性对应了两个类,扩展框架不知道要实例化哪个类了。
接下来的事情才是诡异,笔误,改过来就行了吧?
改成正确的,如下所示:

 1 [Gender(Gender::Male)]
 2 public class Person_Male extends Person
 3 {
 4     public str fromWhere()
 5     {
 6         return "Mars";
 7     }
 8 
 9 }
10 
11 [Gender(Gender::Female)]
12 public class Person_Female extends Person
13 {
14     public str fromWhere()
15     {
16         return "Venus";
17     }
18 
19 }

就算改成正确的,它也还是会报同样的错。
开始以为是缓存的问题,整个model编译没用,各种重启没用,删掉metadata也没用,同步整个Database可以修复,但是按理说这种代码的属性不应该在database里,同步Database可以修复这个问题让人觉得不明所以。
后来跟踪了一下代码发现,SysExtension框架会把实例化得到的metadata反射信息存到SysLastValue表里,就是那张存放用户上次操作信息的表。
清理一下用户选项->应用数据,清理。
在正式环境不存在这个问题,因为每次发布都会同步数据库,同步数据库的时候会清理SysLastValue存的SysExtension信息。

posted on 2020-06-19 18:12  佛西亚  阅读(299)  评论(0编辑  收藏  举报