2012-04-12 18 views
0

私はMVC3が新しく、注文画面を作成しようとしています。ユーザがログインして最近の注文を見ることができます。これは、データベースからユーザー名の値を取り出し、現在のログインしているユーザーと比較しようとしているため、各ユーザーが自分の注文と誰も見ることができないようにするために、問題を証明しています。しかし、私はデータベースからの値を文字列として変換して、ログインしたユーザー名と比較するのに苦労しています。ここでデータベースのユーザ名を確認してください。ログインしたユーザ名MVC3

は私のモデル

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Web; 
using System.ComponentModel; 
using System.ComponentModel.DataAnnotations; 
using System.Web.Mvc; 

namespace Assignment2.Models 
{ 
    public partial class Order 
    { 
     [ScaffoldColumn(false)] 
     public int OrderId      { get; set; } 

     [ScaffoldColumn(false)] 
     public System.DateTime OrderDate { get; set; } 

     [ScaffoldColumn(false)] 
     public string Username     { get; set; } 

     [Required(ErrorMessage = "First Name is required")] 
     [DisplayName("First Name")] 
     [StringLength(160)] 
     public string FirstName     { get; set; } 

     [Required(ErrorMessage = "Last Name is required")] 
     [DisplayName("Last Name")] 
     [StringLength(160)] 
     public string LastName     { get; set; } 

     [Required(ErrorMessage = "House Number/Name")] 
     [StringLength(70)] 
     public string House     { get; set; } 

     [Required(ErrorMessage = "Street Name is required")] 
     [StringLength(70)] 
     public string Address1     { get; set; } 

     public string Address2     { get; set; } 

     [Required(ErrorMessage = "City is required")] 
     [StringLength(40)] 
     public string City      { get; set; } 

     [Required(ErrorMessage = "County is required")] 
     [StringLength(40)] 
     public string County     { get; set; } 

     [Required(ErrorMessage = "Post Code is required")] 
     [DisplayName("PostCode")] 
     [StringLength(10)] 
     public string Postcode     { get; set; } 

     [Required(ErrorMessage = "Country is required")] 
     [StringLength(40)] 
     public string Country     { get; set; } 

     [Required(ErrorMessage = "Phone number is required")] 
     [StringLength(24)] 
     public string Phone      { get; set; } 

     [Required(ErrorMessage = "Email Address is required")] 
     [DisplayName("Email Address")] 
     [RegularExpression(@"[A-Za-z0-9._%+-][email protected][A-Za-z0-9.-]+\.[A-Za-z]{2,4}", 
     ErrorMessage = "Email is is not valid.")] 
     [DataType(DataType.EmailAddress)] 
     public string Email      { get; set; } 

     [ScaffoldColumn(false)] 
     public decimal Total     { get; set; } 


     public List<OrderDetail> OrderDetails { get; set; } 
    } 
} 

そして、ここで私はあなたのユーザーオブジェクトの外観を何私のコントローラで

using System.Web.Security; 
using System.Web.Mvc; 
using Assignment2.Models; 

namespace Assignment2.Controllers 
{ 
    public class OrderController : Controller 
    { 
     private RevolutionEntities db = new RevolutionEntities(); 

     public ViewResult Index() 
     { 
      string loggedinuser = User.Identity.Name; 
      string username = 
          from a in db.Orders 
          where a.Username == loggedinuser 
          select a;        
      return View(); 
    } 
} 

おかげ ジェイミー

+0

をやろうとしているものですです好き? User.Identity.Nameの属性とデータ型は何ですか? – Brian

答えて

0
var orders = db.Orders.Orders(p=>p.UserName == loggedinuser); 
関連する問題