首页 > 其他 > 详细

不存在从对象类型 System.Data.Objects.ObjectParameter 到已知的托管提供程序本机类型的映射

时间:2014-12-08 19:25:08      阅读:621      评论:0      收藏:0      [点我收藏+]

在使用EF的时候  试着直接使用T-SQL

有这样的实现ObjectContext.ExecuteStoreQuery

其中有个构造函数ObjectContext.ExecuteStoreQuery(string s,parm object[] p)

网上全是这种写法

se.ExecuteStoreQuery<Departments>("SELECT dId, dName, dManager FROM Departments where did=@id", new ObjectParameter("id", "1")

我不知道别人是否运行过  或者运行是不是正确 反正我遇到异常了

bubuko.com,布布扣

修改后

se.ExecuteStoreQuery<Departments>("SELECT dId, dName, dManager FROM Departments where did={0}","1")

运行通过 数据正确

原因:parm部分需要如下这种方式构造

context.ExecuteStoreQuery<Product>("select * from Products where pid = {0}", 1);

or

context.ExecuteStoreQuery<Product>("select * from Products where pid = @p0", new SqlParameter { ParameterName = "p0", Value = 1 });

不存在从对象类型 System.Data.Objects.ObjectParameter 到已知的托管提供程序本机类型的映射

原文:http://www.cnblogs.com/dyms/p/4151558.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!