可以';我看不到从SQL Server数据库加载页面的网格视图

本文关键字:加载 数据库 视图 网格 Server SQL 我看 看不到 可以 | 更新日期: 2023-09-27 18:28:35

我做了一个简单的gridview示例,不知道为什么,但网站上根本不存在gridview。

这是我在浏览器中得到的图片-什么都没有。。。http://ipic.su/img/img7/fs/example.1414716455.jpg

有人能看出什么错误吗?

<%@Page Language="C#" AutoEventWireup="true" MasterPageFile="~/Site.Master" CodeFile="InvoiceEdit.aspx.cs" Inherits="InvoiceEdit" EnableEventValidation="false" %>
<asp:Content runat="server" ID="BodyContent" ContentPlaceHolderID="MainContent">
  <style>
.gridview 
{
    background: red;
    border:dashed 1px blue;
}
</style>
  <asp:GridView ID="gvInvoice" runat="server"            
    AutoGenerateColumns="False" 
    OnRowDataBound="gvInvoice_RowDataBound"
    DataKeyNames="InvoiceID"   
    AutoGenerateEditButton="False" 
    CellPadding="1" Width="100%" 
    datasourceid="SqlDataSource1"
    CssClass ="gridview">
<Columns >
    <asp:BoundField HeaderText="InvoiceID" DataField="InvoiceID" ReadOnly="true" /> 
    <asp:BoundField HeaderText="RechnNummer" DataField="RechnNummer" ReadOnly="true" />
    <asp:BoundField HeaderText="Kunde" DataField="Kunde" ReadOnly="true" />
    <asp:BoundField HeaderText="Text" DataField="Text" ReadOnly="true"/>            
</Columns>
</asp:GridView>
----TEST TEXT----
<asp:sqldatasource id="SqlDataSource1"          
    selectcommand="Select * from Invoice where InvoiceID = @InvoiceID"
    updatecommand="Update Invoice set RechnNummer = @RechnNummer, Kunde=@Kunde, Text=@Text, RechnDatum=@RechnDatum, Netoo=@Netoo,
                  Umsatzsteuer=@Umsatzsteuer, Brutto=@Brutto, Eingang=@Eingang where InvoiceID = @InvoiceID"        
    connectionstring="<%$ ConnectionStrings:Invoice%>"
    runat="server" >    
    <SelectParameters> 
        <asp:ControlParameter ControlID="gvInvoice" PropertyName="SelectedValue" Name="InvoiceID" />
    </SelectParameters>
    <UpdateParameters>
        <asp:ControlParameter ControlID="gvInvoice" PropertyName="SelectedValue" Name="InvoiceID" />
    </UpdateParameters>
  </asp:sqldatasource>
</asp:Content>

后面的代码几乎是空的,但我认为这无关紧要。。。也许某个图书馆不见了?或者出了什么问题?谢谢你的回答!

public partial class InvoiceEdit : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)  
    {      
    }
    protected void gvInvoice_RowDataBound(object sender, GridViewRowEventArgs e)
    {
        if (e.Row.RowType == DataControlRowType.DataRow)
        { 
            e.Row.Attributes.Add("onmouseover",    "this.originalstyle=this.style.backgroundColor;this.style.backgroundColor='#C2C2C2'");
            e.Row.Attributes.Add("onmouseout","this.style.backgroundColor=this.originalstyle;");
            e.Row.Attributes["style"] = "cursor:pointer";
        }
   }
}

可以';我看不到从SQL Server数据库加载页面的网格视图

试试这个。

添加文本字段:

 <asp:TextBox ID="txtInvoiceID" runat="server"></asp:TextBox>

更改数据源代码上的Select语句和Select Parameter:

 <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:Invoice %>"
    SelectCommand="Select * from Invoice where InvoiceID = @InvoiceID OR @InvoiceID IS NULL" CancelSelectOnNullParameter="false">
    <SelectParameters>
        <asp:QueryStringParameter Name="InvoiceID" DbType = "String" Direction = "Input" QueryStringField="Id" DefaultValue="" ConvertEmptyStringToNull="True" />
    </SelectParameters>
</asp:SqlDataSource>

代码背后:

protected void Page_Load(object sender, EventArgs e)
{
    if (!IsPostBack)
    {
        txtInvoiceID.Text = Request.QueryString["Id"];
    }
}
protected void btnRedirect_Click(object sender, EventArgs e)
{
    Response.Redirect("~/Default.aspx?Id=" + txtInvoiceID.Text.Trim());
}

必须添加SQL参数。。数据网格中没有数据,因此数据网格不可见。