I keep getting the exception
The SqlParameterCollection only accepts non-null SqlParameter type objects, not String objects
, while execut
I replaced my reference to System.Data.SqlClient with Microsoft.Data.SqlClient corrected the using statements and my problems went away
In my .csproj I now have
But I also found I had use of the following scenario where I created a System.Data.SqlClient.SqlParameter
public static List RunQuery(ApiDbContext context, string query, Func map, params SqlParameter[] parameters)
{
var cn = context.Database.GetDbConnection();
var oldState = cn.State;
if (cn.State.Equals(ConnectionState.Closed)) { cn.Open(); }
using (var command = cn.CreateCommand())
{
command.CommandText = query;
command.CommandType = CommandType.Text;
foreach (var param in parameters)
{
var p = new System.Data.SqlClient.SqlParameter
{
ParameterName = param.ParameterName, Value = param.Value, SqlDbType = param.SqlDbType
};
command.Parameters.Add(p);
}
if (cn.State.Equals(ConnectionState.Closed)) { cn.Open(); }
var entities = new List();
using (var result = command.ExecuteReader())
{
while (result.Read())
{
entities.Add(map(result));
}
}
if (oldState.Equals(ConnectionState.Closed) && cn.State == ConnectionState.Open) { cn.Close(); }
return entities;
}
}