5

現在取り組んでいるプロジェクトについて質問があります。

私はこのコードを持っています:

 var query = from user in dwe.UsersTable
                        where user.LoginName.Equals(usernameBox.Text) && user.Password.Equals(pwBox.Text)
                        select user;

        if (query.Count() == 1)
        {
            Session["User"] = usernameBox.Text;                     
            Response.Redirect("Edit.aspx");
        }
        else
        {
            LabelError.Text = "Error try again";
        }
    }

私の「UsersTable」には、「UserID」という名前の列があります。リダイレクトされたページ (Edit.aspx) へのセッションとして "userID"を送信したいのですが、userID は、ユーザー名とパスワードの比較の結果と等しくなければなりません。

4

2 に答える 2

6

あなたはただ書き留める必要があります

var query = (from user in dwe.UsersTable 
                        where user.LoginName.Equals(usernameBox.Text) && 
                        user.Password.Equals(pwBox.Text)
                         select user).FirstOrDefault();

if(query!=null)
{
   Session["User"] = query.UserID; 
   Response.Redirect("Edit.aspx"); 
}
else
{
   LabelError.Text = "Error try again";
}

これの代わりに Count メソッドを使用する dow コードを記述する必要はありません。単に Of を使用するFirstOrDefaultと、簡単に結果が得られます。

于 2012-09-24T08:09:37.247 に答える
3
var query = from user in dwe.UsersTable
            where user.LoginName.Equals(usernameBox.Text) 
                  && user.Password.Equals(pwBox.Text)
            select user;

// get user from query
// If SingleOrDefault is not supported (<4.0) use FirstOrDefault instead. 
// Thanks Tim Schmelter
var user = query.SingleOrDefault(); 

if (user != null)
{
    Session["UserID"] = user.UserID;                 
    Response.Redirect("Edit.aspx");
}
else
{
    LabelError.Text = "Error try again";
}
于 2012-09-24T08:07:27.513 に答える