首页 > 技术文章 > MVC 5 调用存储过程参数配置方法-Procedure or function 'UP_***' expects parameter '@****', which was not supplied.

adandelion 2019-01-30 16:13 原文

MVC 5 调用存储过程参数配置方法-Procedure or function 'UP_***' expects parameter '@****', which was not supplied.

通过Database.SqlQuery调用SQL2016的存储过程,传入参数,返回结果集合。总是报如下错误

Msg 201, Level 16, State 4, Procedure UP_***, Line 0 [Batch Start Line 15]
Procedure or function 'UP_***' expects parameter '@****', which was not supplied.

 总结如下:

 

1.调用的参数sql里除了包括存储过程外,还需要包含参数的名称

2.参数的顺序必须要和存储过程里参数的顺序一模一样,否则就会报错。(参数名称可以和存储过程里的名称可以不一样,顺序必须一模一样,数据库sp_executesql是通过参数顺序来匹配的,而不是参数的名称来匹配)

string sql = @" UP_存储过程名称  @参数1,@参数2,@参数3,@参数4";
            var sqlParams = new SqlParameter[] {
                new SqlParameter("@参数1", 2),
                new SqlParameter("@参数2", 1),
                new SqlParameter("@参数3", 50),
                new SqlParameter("@参数4", 1))
            };
          
            return View(db.Database.SqlQuery<Poesy>(sql, sqlParams).ToList());

 

推荐阅读