使用String类型变量中的值作为tablename

时间:2013-03-27 18:06:48

标签: c# .net dynamic

在我的C#代码中,我正在使用存储过程从数据库中检索数据,我正在动态创建表(我的意思是.Net中的GUI表)并动态地将行和列添加到该表。我有4张桌子和1张桌子。 4个相应的存储过程。我没有为每个表编写一个方法,而是想编写一个方法,该方法将从四个方法(4个按钮点击方法)中调用,因为只有存储过程名称&表名将被更改,其他所有内容都保持不变。我正在尝试使用以下代码。

    public String StoredProcName; //Values will be "GetFirstYearCSESubjects","GetSecondYearCSESubjects","GetThirdYearCSESubjects","GetFourthYearCSESubjects"
    public String TableName; //Values will be "tblCSE1","tblCSE2","tblCSE3","tblCSE4"
    protected void tabCSE1_Click(object sender, EventArgs e)
    {
        CSEView.ActiveViewIndex = 0;      
        StoredProcName = "GetFirstYearCSESubjects";
        TableName = "tblCSE1";
        phCSE1.Controls.Clear();
        Table tblCSE1 = new Table();
        phCSE1.Controls.Add(tblCSE1);
        addCurriculumData(StoredProcName, TableName);
        ViewState["dynamictable"] = true;
    }

    public void addCurriculumData(String StoredProcName,String TableName)
    {
        String strCon = ConfigurationManager.ConnectionStrings["ConStr"].ConnectionString;
        SqlConnection sqlCon = new SqlConnection(strCon);
        SqlCommand cmd = new SqlCommand(StoredProcName, sqlCon);
        cmd.CommandType = CommandType.StoredProcedure;
        sqlCon.Open();
        SqlDataReader rdr = cmd.ExecuteReader();
        if (rdr.HasRows)
        {
            while (rdr.Read())
            {
                TableRow tr = new TableRow();
                for (int j = 0; j < 1; j++)
                {
                    TableCell tc = new TableCell();
                    Label lbl = new Label();
                    lbl.Text = rdr["Subject"].ToString();
                    tc.Controls.Add(lbl);
                    tr.Cells.Add(tc);
                }
                TableName.Rows.Add(tr);***//How should I write this statement???***
            }
        }
        else
            lblMessage.Text = "No Data found";
    }

我不确定我该怎么写这句话TableName.Rows.Add(tr)。由于TableName是一个字符串,它不能有行,因此它会抛出错误。所以我应该在TableName而不是TableName中提到值。我该怎么办?我可以使用指针的概念吗?我不太确定指针。或者还有另一种方法吗?

提前致谢

1 个答案:

答案 0 :(得分:0)

将表(不是字符串)传递给方法并与表

交互
public void addCurriculumData(String StoredProcName,Table table)