在我继承的 C# WebApp 项目中工作。我有几个函数定义......
public static DataTable ExecuteDT(this AppDBContext target, string sql, int timeoutSeconds = defaultTimeoutSeconds) {
DbCommand cmd = target.Database.Connection.CreateCommand();
cmd.CommandText = sql;
cmd.CommandType = System.Data.CommandType.Text;
if (timeoutSeconds != defaultTimeoutSeconds) cmd.CommandTimeout = timeoutSeconds;
DataTable rv = new DataTable();
rv.Load(cmd.ExecuteReader());
return rv.Copy();
}
public static object ExecuteDR(this AppDBContext target, string sql, int timeoutSeconds = defaultTimeoutSeconds) {
DataTable dt = target.ExecuteDT(sql, timeoutSeconds);
return (ReferenceEquals(dt, null) || dt.Rows.Count == 0) ? null : dt.Rows[0];
}
当我在应用程序上进行构建时,它编译良好,错误为零。
但是,当我尝试运行该网站(使用 F5)时,它会在我的浏览器中启动,然后出现编译错误:
Compiler Error Message: CS0121: The call is ambiguous between the following methods or properties:
'ConstructionLoan.WebFormsApp.DataExtensions.ExecuteDT(ConstructionLoan.Domain.Data.AppDBContext, string, int)' and
'ConstructionLoan.WebFormsApp.DataExtensions.ExecuteDT(ConstructionLoan.Domain.Data.AppDBContext, string, int)'
Source Error:
Line 34:
Line 35: public static object ExecuteDR(this AppDBContext target, string sql, int timeoutSeconds = defaultTimeoutSeconds) {
Line 36: DataTable dt = target.ExecuteDT(sql, timeoutSeconds);
Line 37: return (ReferenceEquals(dt, null) || dt.Rows.Count == 0) ? null : dt.Rows[0];
Line 38: }
Source File: c:\Users\myuser\Source\Workspaces\ourclient\src\Web\Main\ConstructionLoan.WebFormsApp\App_Code\DataExtensions.cs Line: 36
它抱怨相同的确切功能与自身模棱两可。我已经对所有源代码进行了搜索,这是该函数的唯一声明,所以我真的对编译器感到困惑的是摸不着头脑。
我在 Google 上发现的唯一一个与此类似的问题是有人的项目以某种方式最终引用了自己。我仔细检查以确保该项目没有引用自身,而事实并非如此。
我也尝试过对项目进行清理和重建。
无论出于何种原因,这个项目在 IDE 中编译得很好,但是当尝试在浏览器中运行它时,它就出错了。
我在 VS 2015 中工作,目标是 4.5.2 版本的框架。