0

Data list这个问题与我几天前发布的类似问题有关。我有一个显示类别的数据列表,然后是类别中的文档。需要发生的是每个类别下的文档根据文件名中的一些数字按顺序显示。文档的格式类似于“001-filename.pdf”、“002-filename.pdf”...“00x-filename.pdf”。我可以将第一个破折号用作某种“拆分”功能,然后抓取“001”等数字以使排序正常工作。我认为这可以在任itemdatabound一或 sql 语法中完成。我在这里发布相关代码。关于如何使它起作用的任何想法?可能有多个文档具有共享编号前缀:“001-filename.pdf”、“001-filenameversion2.pdf”等。

ASPX:

<asp:DataList ID="DataList1" runat="server" RepeatDirection="Vertical" DataKeyField="docid"
    EnableViewState="True" OnItemDataBound="DataList1_ItemDataBound">
    <ItemTemplate>
        <table cellpadding="0" cellspacing="0" id="tbl_data">
            <tr runat="server" id="tr_category">
                <td>
                    <asp:Label ID="lblHeader" runat="server" Font-Bold="True" Text='<%# Eval("categoryname") %>'
                        Font-Underline="True"></asp:Label>
                    <asp:Label runat="server" ID="lbl_cb_all">Select All
                        <asp:CheckBox runat="server" OnCheckedChanged="CheckAllChanged" AutoPostBack="true"
                            ID="cb_selectall" />
                    </asp:Label>
                    <asp:HiddenField ID="HiddenCatID" runat="server" Value='<%# Eval("CatID") %>' />
                    <asp:HiddenField ID="HiddenDocID" runat="server" Value='<%# Eval("docid") %>' />
                </td>
            </tr>
            <tr runat="server" id="tr_data">
                <td>
                    <asp:CheckBox runat="server" ID="cb_docid" Value='<%# Eval("docid") %>' OnCheckedChanged="displayselectedinit"
                        AutoPostBack="true" />
                    <asp:HyperLink ID="hpl_docfileencr" Text='<%# Eval("docfileencr") %>' NavigateUrl='<%# "~/PDFEncr/" + DataBinder.Eval(Container.DataItem, "docfileencr") %>'
                        Target="_blank" runat="server" />
                    <br />
                </td>
            </tr>
        </table>
    </ItemTemplate>
</asp:DataList>

C#代码隐藏:

sqlsyntax = @"SELECT  dbo.projectsdocuments.docfileencr,dbo.categories.catid, dbo.categories.categoryname, dbo.projectsdocuments.docid
              FROM dbo.Projects INNER JOIN dbo.projectsdocuments ON (dbo.Projects.projectid = dbo.projectsdocuments.projectid)
              INNER JOIN dbo.categories ON (dbo.projectsdocuments.categoryid = dbo.categories.catid)
              WHERE  Projects.projectid = " + projectid + " ORDER BY dbo.categories.sortorder ASC";

protected void DataList1_ItemDataBound(Object sender, DataListItemEventArgs e)
{
    if (e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem)
    {
        var row = (DataRowView)e.Item.DataItem;
        var view = row.DataView;
        var lastRow = e.Item.ItemIndex == 0 ? null : view[e.Item.ItemIndex - 1];
        var tr_category = (System.Web.UI.HtmlControls.HtmlTableRow)e.Item.FindControl("tr_category");
        var sameCategory = lastRow != null && (int)row["catid"] == (int)lastRow["catid"];
        tr_category.Visible = !sameCategory;
    }
}
4

1 回答 1

1

更改您的 ORDER BY 以包括这两列。

SELECT  
    dbo.projectsdocuments.docfileencr,
    dbo.categories.catid, 
    dbo.categories.categoryname, 
    dbo.projectsdocuments.docid
FROM dbo.Projects 
INNER JOIN dbo.projectsdocuments 
    ON (dbo.Projects.projectid = dbo.projectsdocuments.projectid)
INNER JOIN dbo.categories 
    ON (dbo.projectsdocuments.categoryid = dbo.categories.catid)
WHERE  Projects.projectid = " + projectid + "
ORDER BY dbo.categories.sortorder, dbo.projectsdocuments.docfileencr

优先顺序从左到右,默认为“ASCENDING”,但您可以通过直接在其后添加“ASC 或 DESC”来更改特定列的排序。

** 重要的提示 **

您的代码容易受到SQL 注入的影响,因为您正在执行字符串连接。如果您对此感到担忧,请将 SQL 语句更改为使用您通过命令参数分配的命名参数(参见下面的示例)。

第 1 步: 将内联字符串参数更改为命名参数“@projectid”。

SELECT  
    dbo.projectsdocuments.docfileencr,
    dbo.categories.catid, 
    dbo.categories.categoryname, 
    dbo.projectsdocuments.docid
FROM dbo.Projects 
INNER JOIN dbo.projectsdocuments 
    ON (dbo.Projects.projectid = dbo.projectsdocuments.projectid)
INNER JOIN dbo.categories 
    ON (dbo.projectsdocuments.categoryid = dbo.categories.catid)
 WHERE  Projects.projectid = @projectid
 ORDER BY dbo.categories.sortorder, dbo.projectsdocuments.docfileencr

第 2 步: 内联分配参数(示例代码)

using(SqlConnection conn = new SqlConnection(connString))
{
    conn.Open();

    SqlCommand command = new SqlCommand(sql, conn);
    command.CommandType = CommandType.Text;

    // Assign the value projectid to the parameter @projectid
    command.Parameters.Add(new SqlParameter("@projectid", projectid));

    // Execute The Command (fill dataset, create datareader, etc...)
    SqlDataReader reader = command.ExecuteReader();
}
于 2012-04-18T17:08:42.357 回答