【问题标题】:Why doesn't my GridView show up?为什么我的 GridView 不显示?
【发布时间】:2018-01-17 19:37:24
【问题描述】:

编辑:我忘记绑定数据表(哎呀),现在已修复。程序现在崩溃了,我仍然很困惑为什么。

我正在创建一个网站,我想在其中显示一个已切换行和列的数据表。我写了一些c#来做到这一点。我的代码可以编译并运行而不会崩溃,但我放置这些数据的 gridview 从未出现过。如果我删除将数据绑定到gridview的代码,而是使用sql源连接,它会显示(但显然没有翻转)。

为什么我的 gridview 没有显示,我该如何解决?

C#:

using System;
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

namespace MachineUpdateFrontEnd
{
    public partial class NewUpdate : System.Web.UI.Page
    {
        DataSet input;
        DataSet output;

        protected void Page_Load(object sender, EventArgs e)
        {
            DataSet temp = pullData(UpdateSqlDataSource.ConnectionString);
            input = SwitchRows(temp);
            GridView1.DataSource = input.Tables[0];
        }

        private DataSet pullData(string ConStr) {
            DataSet ds = new DataSet();
            SqlDataAdapter adp = new SqlDataAdapter("select * from MachineUpdate", ConStr);
            adp.Fill(ds, "MachineUpdate");
            return ds;
        }

        private void pushData() {
            output = SwitchRows(input);
        }

        private DataSet SwitchRows(DataSet input)
        {
            DataSet ds = new DataSet();

            foreach (DataTable dt in input.Tables) {
                DataTable inputTable = new DataTable();
                for (int i = 0; i < dt.Rows.Count; i++) {
                    inputTable.Columns.Add(Convert.ToString(i));
                }
                DataRow r;
                for (int j = 0; j < dt.Columns.Count; j++) {
                    r = inputTable.NewRow();
                    r[0] = dt.Columns[j].ToString();
                    for (int k = 1; k < dt.Rows.Count; k++) {
                        r[k] = dt.Rows[k - 1][j];
                    }
                    inputTable.Rows.Add(r);
                }
                ds.Tables.Add(inputTable);
            }
            return ds;
        }
    }
}

平均售价:

<%@ Page Title="" Language="C#" MasterPageFile="~/Master.Master" AutoEventWireup="true" CodeBehind="NewUpdate.aspx.cs" Inherits="MachineUpdateFrontEnd.NewUpdate" %>
<asp:Content ID="Content1" ContentPlaceHolderID="head" runat="server">
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="body" runat="server">
    <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="True" DataKeyNames="UpdateID" style="margin-top: 0px" ShowHeaderWhenEmpty ="true">
        <Columns>
            <asp:BoundField DataField="UpdateID" HeaderText="UpdateID" InsertVisible="False" ReadOnly="True" SortExpression="UpdateID" />
            <asp:BoundField DataField="MachineID" HeaderText="MachineID" SortExpression="MachineID" />
        </Columns>
    </asp:GridView>
    <asp:SqlDataSource ID ="UpdateSqlDataSource" runat ="server" ConnectionString="<%$ ConnectionStrings:MachineUpdateDataBaseConnectionString %>" SelectCommand="SELECT * FROM [MachineUpdate MQ]">

    </asp:SqlDataSource>
</asp:Content>

整个项目:

https://github.com/Darokrithia/MachineUpdateFrontEnd

【问题讨论】:

  • 你调试过你的代码吗?确保生成的 DataSet 包含数据?
  • @mason 除了运行它,我不知道该怎么做
  • 我将教给你你职业生涯中最有价值的东西之一。您将能够逐行遍历您的代码,随时检查值。这将使您能够发现您认为代码应该如何执行与代码实际执行方式之间的差异。 Enjoy.
  • 非常感谢!
  • 根据您对 Rahul 回答的评论,您可能正在尝试访问 DataRow 中不存在的列。您在 SQL 查询中使用 select *。那是代码的味道。您是在说“给我任何列”,而不是说您想要哪个。这很可能掩盖了问题。几乎总是在编写代码时,您应该明确说明您想要哪些列。当你在玩 SQL 时,你应该使用select *

标签: c# sql asp.net gridview


【解决方案1】:

我没有看到您正在将 gridview 与数据源绑定,例如

GridView1.DataSource = input.Tables[0];
GridView1.DataBind();   //missing data binding

【讨论】:

  • 哇,我真傻。现在它只是崩溃了,我想这是一个进步。错误是“System.Data.DataRowView”不包含名为“UpdateID”的属性。”顺便说一句
猜你喜欢
  • 1970-01-01
  • 2015-12-08
  • 1970-01-01
  • 1970-01-01
  • 2013-08-20
  • 1970-01-01
  • 2014-09-27
  • 2012-09-08
相关资源
最近更新 更多