0

这是我在 MVC4 模型中的 IsValid 用户登录代码。

我正在尝试将我的 SQL 命令转换为 LINQ。

如何将其转换为 LINQ 方式?

public bool IsValid(string _username, string _password)
{
    using (var cn = new SqlConnection(@"Data Source=(LocalDB)\v11.0;AttachDbFilename" + 
        @"='C:\Tutorials\1 - Creating a custom user login form\Creating " + 
        @"a custom user login form\App_Data\Database1.mdf';Integrated Security=True")) 
    {
        string _sql = @"SELECT [Username] FROM [dbo].[System_Users] " + 
            @"WHERE [Username] = @u AND [Password] = @p";
        var cmd = new SqlCommand(_sql, cn);
        cmd.Parameters
            .Add(new SqlParameter("@u", SqlDbType.NVarChar))
            .Value = _username;
        cmd.Parameters
             .Add(new SqlParameter("@p", SqlDbType.NVarChar))
             .Value = Helpers.SHA1.Encode(_password);
        cn.Open();
        var reader = cmd.ExecuteReader();
        if (reader.HasRows)
        {
            reader.Dispose();
            cmd.Dispose();
            return true;
        }
        else
        {
            reader.Dispose();
            cmd.Dispose();
            return false;
        }
    }
}
4

2 回答 2

0

我首先会考虑使用实体数据模型(如 Entity Framework ( http://msdn.microsoft.com/en-gb/data/ef.aspx ) 中的实体数据模型)在 C# 中为您的数据库对象建模并将一个添加到您的项目中.

然后我会在你的数据库中创建一个存储过程来处理 SQL 语句的执行,传递你想要测试的参数。

然后,我会将存储过程导入数据模型并对其运行 LINQ 查询。

类似于以下内容:

var valid = (from users in context.CheckUserMembership(userName: userName, password: password)
select new User
{
   UserId = users.UserId,
   UserName = users.Username
}).Count() > 0;  

其中 context 是对实体数据模型向导生成的数据上下文的引用,而 CheckUserMembership 是包含您的 SQL 语句的导入存储过程。

于 2013-05-10T18:32:07.250 回答
0

在为您的应用程序设置 LINQ 或任何 ORM 后,可以将其转换为简单的 LINQ 语句。

return _dbContext.Users.Any(c=>c.UserName == _username && c.Password == Helpers.SHA1.Encode(_password));
于 2013-05-10T18:36:23.860 回答