我试图从C#代码中访问存储过程,但总是得到结果== -1。我不知道我错在哪里。我搜查了很多,但没有找到任何解决方案。请查看我的代码片段,并指导我做错了什么。无法从存储过程中获取数据
在此先感谢。
C#代码:
using (SqlConnection connection = new SqlConnection(getConnectionString()))
using (SqlCommand command = new SqlCommand())
{
Int32 rowsAffected;
command.CommandText = "SP_LOGIN_GETUSERBYNAME";
command.CommandType = CommandType.StoredProcedure;
// command.Parameters.Add(new SqlParameter("@Email", userObj.email));
// command.Parameters.Add("@Email", SqlDbType.VarChar).Value = userObj.email.Trim();
command.Parameters.AddWithValue("@Email", userObj.email.ToString());
command.Connection = connection;
connection.Open();
rowsAffected = command.ExecuteNonQuery();
connection.Close();
return rowsAffected;
}
连接字符串:
return "Data Source=MUNEEB-PC;Initial Catalog=HRPayRoll;User ID=sa; Password=sa";
存储的过程代码:
CREATE PROCEDURE SP_LOGIN_GETUSERBYNAME
@Email varchar(50)
AS
SELECT *
FROM [User]
WHERE Email = @Email
GO
避免使用'sp_'前缀命名存储过程。该前缀用于包含在SQL Server中的系统存储过程。 –
感谢您指导我@Dan :) –