2013-10-12 61 views
0

在asp.net網站使用c#時,我試圖從數據庫表中的下拉列表中獲取產品列表產品我收到調試消息「指定演員不是有效」。任何人都可以指出錯誤?請它真的很緊急。指定的轉換是無效的消息在asp.net上RowFilter

這裏是我的堆棧跟蹤:

[InvalidCastException: Specified cast is not valid.] 
    Order.GetSelectedProduct() +371 
    Order.Page_Load(Object sender, EventArgs e) +40 
    System.Web.Util.CalliHelper.EventArgFunctionCaller(IntPtr fp, Object o, Object t, EventArgs e) +14 
    System.Web.Util.CalliEventHandlerDelegateProxy.Callback(Object sender, EventArgs e) +44 
    System.Web.UI.Control.OnLoad(EventArgs e) +83 
    System.Web.UI.Control.LoadRecursive() +120 
    System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +3955 

Order.aspx.cs:

public partial class Order : System.Web.UI.Page 
{ 

    private Product selectedProduct; 

    protected void Page_Load(object sender, EventArgs e) 
    { 
     if (!IsPostBack) 
      ddlProducts.DataBind(); 
     selectedProduct = this.GetSelectedProduct(); 
     lblName.Text = selectedProduct.Name; 
     lblShortDescription.Text = selectedProduct.ShortDescription; 
     lblLongDescription.Text = selectedProduct.LongDescription; 
     lblUnitPrice.Text = selectedProduct.UnitPrice.ToString("c"); 
     imgProduct.ImageUrl = "Images/Products/" + selectedProduct.ImageFile; 
    } 




    private Product GetSelectedProduct() 
    { 
     DataView productsTable = (DataView) 
      SqlDataSource2.Select(DataSourceSelectArguments.Empty); 
     productsTable.RowFilter = "P_Id = '" + ddlProducts.SelectedValue + "'"; 
     DataRowView row = (DataRowView)productsTable[0]; 
     Product p = new Product(); 
     p.ProductID = row["P_Id"].ToString(); 
     p.Name = row["Title"].ToString(); 
     p.ShortDescription = row["Desc"].ToString(); 
     p.LongDescription = row["Desc_full"].ToString(); 
     p.UnitPrice = (decimal)row["Price"]; 
     p.ImageFile = row["P_image"].ToString(); 
     return p; 
    } 
    protected void btnAdd_Click(object sender, EventArgs e) 
    { 

     if (Page.IsValid) 
     { 
      CartItem item = new CartItem(); 
      item.Product = selectedProduct; 
      item.Quantity = 1; 
      this.AddToCart(item); 
      Response.Redirect("Cart.aspx"); 
     } 

    } 


    private void AddToCart(CartItem item) 
    { 
     SortedList cart = this.GetCart(); 
     string productID = selectedProduct.ProductID; 
     if (cart.ContainsKey(productID)) 
     { 
      CartItem existingItem = (CartItem)cart[productID]; 
      existingItem.Quantity += 1; 
     } 
     else 
      cart.Add(productID, item); 
    } 


    private SortedList GetCart() 
    { 
     if (Session["Cart"] == null) 
      Session.Add("Cart", new SortedList()); 
     return (SortedList)Session["Cart"]; 
    } 
} 

Order.aspx

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Order.aspx.cs" Inherits="Order" %> 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 

<html xmlns="http://www.w3.org/1999/xhtml"> 
<head runat="server"> 
    <title>Welcome to LetsDressUp</title> 
</head> 
<body> 
    <form id="form1" runat="server"> 
    <div> 

    Please select a product: 
     <br /> 

     <asp:DropDownList ID="ddlProducts" runat="server" 
      DataSourceID="SqlDataSource2" DataTextField="Title" DataValueField="P_Id"> 
      <asp:ListItem></asp:ListItem> 
     </asp:DropDownList> 
     <asp:SqlDataSource ID="SqlDataSource2" runat="server" 
      ConnectionString="<%$ ConnectionStrings:ConnectionString %>" 
      SelectCommand="SELECT [P_Id], [Title], [Desc], [Desc_full], [Price], [P_image] FROM [Product]"> 
     </asp:SqlDataSource> 
     <asp:SqlDataSource ID="SqlDataSource1" runat="server" 
      ConnectionString="<%$ ConnectionStrings:ConnectionString %>" 
      SelectCommand="SELECT * FROM [Product]" 
      onselecting="SqlDataSource1_Selecting"></asp:SqlDataSource> 
     <br /> 

     <table> 
     <tr> 


     <td class="style1"> 
        <asp:Label ID="lblName" runat="server" 
         style="font-weight: 700; font-size: larger"> 
        </asp:Label> 
       </td> 
       <td class="style2" rowspan="4"> 
       </td> 
       <td rowspan="4" valign="top"> 
        <asp:Image ID="imgProduct" runat="server" Height="200px" /> 
       </td> 

     </tr> 

     <tr> 
       <td class="style1"> 
        <asp:Label ID="lblShortDescription" runat="server"> 
        </asp:Label> 
       </td> 
      </tr> 
      <tr> 
       <td class="style1"> 
        <asp:Label ID="lblLongDescription" runat="server"> 
        </asp:Label> 
       </td> 
      </tr> 
      <tr> 
       <td class="style1"> 
        <asp:Label ID="lblUnitPrice" runat="server" 
         style="font-weight: 700; font-size: larger"> 
        </asp:Label> 
        <asp:Label ID="Label2" runat="server" Text="each" 
         style="font-weight: 700; font-size: larger"> 
        </asp:Label> 
       </td> 
      </tr> 


     </table> 

     <asp:Button ID="btnAdd" runat="server" onclick="btnAdd_Click" 
      Text="Add to Cart" /> 
&nbsp;<asp:Button ID="btnCart" runat="server" PostBackUrl="~/Cart.aspx" 
      Text="Go to Cart" /> 
    </div> 
    </form> 
</body> 
</html> 

感謝您的幫助。

+0

你幾乎能夠得到您所需要的所有信息在堆棧跟蹤中。問題出在'GetSelectedProduct'方法中。特別是在該代碼隱藏文件中查看第371行。 –

+0

我應該如何將dataview轉換爲datarowview?我究竟做錯了什麼 ? – user2011302

回答

0

您可以使用foreach循環訪問dataview對象的行。

foreach (DataRowView rowView in productsTable) 
{ 
    DataRow row = rowView.Row; 
    // Do something with the row // 

    // and if you just wanted to process the first record 
    // use break to end the loop 
    break; 
} 

或者你可以使用FirstOrDefault擴展方法得到公正的第一行,類似於你試圖在你的方法做

DataRowView rowView = productsTable.FirstOrDefault<DataRowView>() 
+0

它的工作,謝謝! – user2011302