我想在选定的时间间隔中显示一种人员列表和一些与该月的某一天相关的信息,如下所示:
Emp. | 01 | 02 | 03 |
Albert | aaa | bbb | ccc |
Dana | ccc | aaa | bbb |
John | bbb | ccc | aaa |
我设置了这样的中继器:
<asp:TextBox ID="txtDataDa" Type="date" runat="server" ToolTip="Data Da" autocomplete="off"></asp:TextBox>
<asp:TextBox ID="txtDataA" Type="date" runat="server" ToolTip="Data A" autocomplete="off"></asp:TextBox>
<asp:Button ID="btnVai" runat="server" Text="Vai" OnClick="btnVai_Click"/>
<asp:Repeater ID="rptParent" runat="server">
<HeaderTemplate>
<table style="width: 100%;">
<tr>
<td>Dip</td>
</HeaderTemplate>
<ItemTemplate>
<td>
<asp:Label ID="lblGiorno" Text='<%# DataBinder.Eval(Container.DataItem, "data", "{0:dd}")%>' runat="server" />
</td>
<%--<asp:Repeater ID="rptChild" runat="server">
<ItemTemplate>
</ItemTemplate>
</asp:Repeater>--%>
</ItemTemplate>
<FooterTemplate>
</tr>
</table>
</FooterTemplate>
</asp:Repeater>
标签内的 Eval 位从使用 2 个日历控件设置的开始日期和结束日期生成的数据表中获取一天,我在后面的代码中使用此位进行管理:
Protected Sub btnVai_Click(sender As Object, e As EventArgs)
Dim data1, data2 As DateTime
data1 = Date.ParseExact(txtDataDa.Text, "yyyy-MM-dd", CultureInfo.CreateSpecificCulture("en-US")).Date
data2 = Date.ParseExact(txtDataA.Text, "yyyy-MM-dd", CultureInfo.CreateSpecificCulture("en-US")).Date
Dim dtGiorni As New DataTable
' Define columns
dtGiorni.Columns.Add("data", GetType(System.DateTime))
dtGiorni.Columns.Add("giorno", GetType(System.String))
' Add a row of data
Dim data As DateTime = data1.AddDays(-1)
Dim ita As Globalization.CultureInfo = New Globalization.CultureInfo("it-IT")
While data < data2
data = data.AddDays(1)
Dim nomeGiorno As String = ita.DateTimeFormat.GetDayName(data.DayOfWeek)
dtGiorni.Rows.Add(data, nomeGiorno.Substring(0, 1).ToUpper() + nomeGiorno.Substring(1))
End While
rptParent.DataSource = dtGiorni
rptParent.DataBind()
End Sub
如果我选择 3 月 1 日和 31 日,它会正确显示所有标题列,其中写有日期。现在我想根据 mssql 查询的结果创建未定义的行数,以显示第一列中的人员以及正确日期的所有信息。我想我必须使用嵌套中继器,但我不知道如何将其与表的其余部分一起设置。有什么帮助吗?谢谢
编辑: 我不介意使用其他方法而不是中继器,但请给出一些开始的提示
如果没有最重要的原因,我不会这样做。
我要么使用 AutoGenerateColumns 设置为 true 的 GridView,要么完全在服务器上构建 html(放入 aspx 上定义的文字中)。
从技术上讲,您可以使用中继器来完成此操作,但这将需要大量额外的工作,而回报却很少。而且代码的可读性不是很好。
编辑:如何连接网格视图
<asp:TextBox ID="txtDataDa" Type="date" runat="server" ToolTip="Data Da" autocomplete="off"></asp:TextBox>
<asp:TextBox ID="txtDataA" Type="date" runat="server" ToolTip="Data A" autocomplete="off"></asp:TextBox>
<asp:Button ID="btnVai" runat="server" Text="Vai" OnClick="btnVai_Click"/>
<asp:gridview id="grdList" runat="server" autogeneratecolumns="True"
emptydatatext="No data available." useaccessibleheader="false" >
</asp:gridview>
然后是后面的代码:
Protected Sub btnVai_Click(sender As Object, e As EventArgs)
Dim data1, data2 As DateTime
data1 = Date.ParseExact(txtDataDa.Text, "yyyy-MM-dd", CultureInfo.CreateSpecificCulture("en-US")).Date
data2 = Date.ParseExact(txtDataA.Text, "yyyy-MM-dd", CultureInfo.CreateSpecificCulture("en-US")).Date
Using cn As New ODBCDataConnection(conString)
cn.open
Using cmd As OdbcCommmand = cn.createcommand
cmd.commandtext = "your mysql statement"
// Use parameters for date range
grdList.DataSource = cmd.ExecuteReader()
grdList.DataBind()
end using
End Using
End Sub
Pivot 将帮助您构建数据。 learn.microsoft.com/en-us/sql/t-sql/queries/...。
它将深表更改为宽表,并且使用动态 SQL,您可以在数据透视表中拥有可变数量的列。 stackoverflow.com/questions/198716/pivot-in-sql-2005#199763