3

SqlParameterObjectParameter之间的主要区别是什么?SqlParameter vs ObjectParameter

ObjectParameter[] parameters = 
{ 
      new ObjectParameter("MainUserName", user.MainUserName), 
      new ObjectParameter("MainUserFirstName",user.MainUserFirstName), 
      new ObjectParameter("MainUserLastName",user.MainUserLastName), 
      new ObjectParameter("DOJoin", DateTime.Now), 
}; 

SqlParameter[] parameters = 
     { 
      new SqlParameter("@MainUserName", user.MainUserName), 

      new SqlParameter("@MainUserFirstName",user.MainUserFirstName), 

      new SqlParameter("@MainUserLastName",user.MainUserLastName), 



      new SqlParameter("@DOJoin", DateTime.Now), 

     }; 

我正在使用MVC代码首先,我想通过存储过程与我的数据库进行通信。 那么哪一个是将参数传递给SP的最佳方法? 我最后一次尝试通过传递的Sql Perameters来执行SP但面对下面的例外

Procedure or function 'InsertUser' expects parameter '@MainUserName', which was not supplied 

我试图通过尝试不同的方案来解决,但没有运气。 最后我想我应该使用Sql Perameters的Object Perameters intead。 但不知道这些之间的主要区别是什么?

Edite 我想运行使用ExecuteSqlCommandAsync我下面的代码,希望object[] parameters

public async Task InsertAsync(ActionCriteria obj) 
{ 
    await _dbCOntext.Database.ExecuteSqlCommandAsync(obj.SpName, obj.SqlParameter) ; 
} 

public Task<int> ExecuteSqlCommandAsync(string sql, params object[] parameters); 

所以我将如何传递sqlperameters到ExecuteSqlCommandAsync,使之可以与提供执行SP SqlParameters not ObjectParameters

回答

4

SqlParameter是ADO.NET的一部分,它的可能是如果底层数据库是SQL Server,则用于EF。例如在context.Database.SqlQuery方法中。

ObjectParameter是EF的一部分(看它的程序集名称),EF可以与许多DBMS一起使用(当然每个案例都有特殊的提供者)。 ObjectParameter不需要SQL Server。 SqlParameter呢。

这两个类都用于执行SP和原始SQL查询。我建议在SQL Server数据库的情况下,这些类之间没有概念上的区别。