gpt4 book ai didi

c# - 不存在从 ObjectParameter 到已知托管提供程序 native 类型的映射

转载 作者:太空狗 更新时间:2023-10-30 00:31:46 27 4
gpt4 key购买 nike

我正在使用 EF 为 Microsoft SQL Server 构建 WCF 服务,但不断收到以下错误:

Additional information: No mapping exists from object type System.Data.Objects.ObjectParameter to a known managed provider native type.

关于这个查询:

string ID = "XXID";
string Sql = @"SELECT * FROM @Table WHERE " + ID + " LIKE '@SearchTerm'";
ObjectParameter[] Parameters = new ObjectParameter[2];
Parameters[0] = new ObjectParameter("Table", Table);
Parameters[1] = new ObjectParameter("SearchTerm", SearchTerm);

using (var Context = new XXEntities())
{
Context.Database.Connection.Open();
IEnumerable<string> Query = Context.Database.SqlQuery<string>(Sql, Parameters);

string[] Results = Query.ToArray();
Context.Database.Connection.Close();
return Results;
}

我已经在 SQL Server 上测试了查询,它按预期工作 - 返回匹配 ID 的记录。

最佳答案

尝试使用sql参数代替对象参数

IEnumerable<string> Query = Context.Database.SqlQuery<string>(Sql, 
new SqlParameter("Table", Table),
new SqlParameter("SearchTerm", SearchTerm));

理论上你可以在不需要像这样发送任何参数的情况下操作sql

IEnumerable<string> Query = Context.Database.SqlQuery<string>("SELECT * FROM "+Table+" WHERE " + ID + " LIKE '"+SearchTerm+"'");

关于c# - 不存在从 ObjectParameter 到已知托管提供程序 native 类型的映射,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22943996/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com