问题出现
今天在测试实施反馈的问题时,调试接口代码发现报错和服务器上返回的不一样(这个接口已经半年没有进行修改了),于是拿着日志里面的入参进行调试,突然发现访问数据库的代码报错。
寻找方法
一开始还以为是sql有问题,后面发现调用ExecuteDataTable方法时会有返回类型初始值设定项引发异常的错误,网上很多说都是值没有初始化,然后定位到具体的报错,沿着未初始化的思路走,结果发现是定义了数据库名,但是appsettings.json文件里面没有配置对应的数据库内容。
解决问题
最后翻看git和询问相关人员,才发现是有同事离职前没有把代码传完全,才导致了这个问题
P.S.接口代码所使用的是工厂模式,加载全局配置时因为调用GetSection方法未能找到新增的数据库HIS3配置,所以catch掉了