C# Can';在从SQL Server数据库加载页面时看不到我的gridview

C# Can';在从SQL Server数据库加载页面时看不到我的gridview,c#,sql,asp.net,sql-server,gridview,C#,Sql,Asp.net,Sql Server,Gridview,我做了一个简单的gridview示例,不知道为什么,但是gridview在网站上根本不存在 这是我在浏览器中得到的图片-没有 有人能看出什么错误吗 <%@Page Language="C#" AutoEventWireup="true" MasterPageFile="~/Site.Master" CodeFile="InvoiceEdit.aspx.cs" Inherits="InvoiceEdit" EnableEventValidation="false" %> <as

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

这是我在浏览器中得到的图片-没有

有人能看出什么错误吗

<%@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>
试试看

添加文本字段:

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

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

检查数据源。你有什么数据吗?请看这张图片,如果我使用设计模式,我可以看到gridview,但我不能在那里编辑它…嗯。遗憾的是,我没有得到任何错误,它发生在我的第一次设计模式只是向您显示一些虚拟数据。这并不意味着你可以从数据库中获取数据。查看一下您的数据源。你的连接字符串在哪里?检查其是否正确您可以测试您的SQL数据源,看看它是否连接到数据库我的连接字符串在网络配置中我在这台电脑上还有一个大项目,它有相同的shema,可以工作>。谢谢,但我工作了一整晚,终于解决了这个问题。SQL连接被窃听了(不知道为什么),我只是从null开始做了一次
 <asp:TextBox ID="txtInvoiceID" runat="server"></asp:TextBox>
 <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());
}