asp.net C中的网格视图使用问题#

时间:2011-06-16 06:12:39

标签: c# asp.net gridview templatefield

我想用GridView和其他两个字段填充HyperLink

我半心半意地尝试了下面的方法。这是错误的。

SqlCommand comm = new SqlCommand(
    @"Select 
        FileUpload.FileName AS FileName,
        FileUpload.FilePath AS PATH,
        SubjectMaster.SubjectName AS Subject,
        MemberPersonalInformation.FirstName As SharedBy 
    from FileUpload 
    INNER JOIN ContentManagement 
        ON ContentManagement.FileId=FileUpload.FileId  
    INNER JOIN MemberPersonalInformation 
        ON MemberPersonalInformation.MemberId=ContentManagement.CreatedBy 
    INNER JOIN SubjectMaster 
        ON ContentManagement.SubjectName=SubjectMaster.SubjectId  
    where 
        FileUpload.FileId in
        (
            Select FileId 
            from ContentManagement 
            where 
                ContentId in
                (
                    Select ContentId 
                    from ContentToIndividual 
                    where ShowToMemberId=@MemberId
                ) and 
                ContentManagement.ContentTypeId=@TPD and
                ContentManagement.SessionId=@SessionId
        )", conn);

      conn.Open();
        SqlDataReader rdr = comm.ExecuteReader();
        int i = 0;
        while (rdr.Read())
        {
            string fip = rdr["PATH"].ToString();
            GridViewRow di = GridView1.Rows[i];

                HyperLink h1 = (HyperLink)di.FindControl("Hyperlink1");
                h1.Text = rdr["FileName"].ToString();
                h1.NavigateUrl = "download.aspx?filepath=" + fip;

                di.Cells[1].Text = rdr["SharedBy"].ToString();
                di.Cells[2].Text = rdr["Subject"].ToString();

                i++;

        }
        rdr.Close();

获取错误消息

  

指数超出范围。一定是   非负和小于的大小   集合。
参数   名称:索引

如果有人建议我采用更好的方法或纠正此错误,请

4 个答案:

答案 0 :(得分:1)

GridView.Rows集合索引从零开始。您需要使用初始化i

i变量的值超过GridView.Rows集合中的可用索引时,会发生错误。因此,如果使用 0 初始化i变量无法解决问题,那么返回的结果集(由读者处理)会比GridView.Rows集合包含更多项目。 / p>

要确保i变量的值不超过GridView.Rows集合的可用索引,请使用以下内容:

while (rdr.Read() && i < gridView.Rows.Count)

如果您需要向GridView添加行,请使用以下内容:

while (rdr.Read() && i < 3)
{
    string fip = rdr["PATH"].ToString();
    GridViewRow di = new GridViewRow();

    ....

    gridView.Rows.Add(di);        
    i++;        
}

另一个原因可能是您用来引用GridViewRow.Cells中的项目的索引。

答案 1 :(得分:1)

确保您的gridview至少有三个,否则此行将抛出您描述的异常:

di.Cells[2].Text = rdr["SharedBy"].ToString();

另一方面,你需要注意这一行:

 h1.NavigateUrl = "download.aspx?filepath=" + fip;

将路径传递给客户端然后返回服务器是引入安全问题的好方法,请确保download.aspx检查filepath参数是否为真正应该可下载的文件!! :)

答案 2 :(得分:0)

设置int i = 0;并检查,索引从0开始而不是1

答案 3 :(得分:0)

我认为您的读者收集计数与网格行数的大小不匹配,这就是为什么它给出“索引超出范围”检查这个 进行检查

if(GridView1.Rows.Count  > i)

然后在你想要的表演之后