开发者

c# error with dataset update

I have list of type string with name temp1 in this list i have a group of words for each word im calculating N00,N01,N10,N11,MI at last it is throwing exception Update unable to find TableMapping['sample'] or DataTable 'sample'..plz help

DataSet dsSelectAll = new DataSet();
    SqlCommand cmdSelectAll = new SqlCommand("select * from sample", con);
    SqlDataAdapter daSelectAll = new SqlDataAdapter(cmdSelectAll);
    SqlCommandBuilder scb = new SqlCommandBuilder(daSelectAll);
    daSelectAll.FillSchema(dsSelectAll,SchemaType.Mapped, "sample");

    foreach (string ri in temp1)
    {
        //for (int a3 = 0; a3 < ssl.Count; a3++)
        {


                cmdT.CommandText = @"SELECT * FROM [vijay].[dbo].[sample] where keyword in ('y','" + ri + "')";
               // ds.Tables.Clear();
                da.Fill(ds);

                // row 1 ::     1   0   0   1   0   0
                // row 2::      2   7   0   0   0   1   

                int N00 = 0;
                int N01 = 0;
                int N10 = 0;
                int N11 = 0;

                for (int i = 0; i < ds.Tables[0].Columns.Count; i++)
                {
                    // N00
                    if (ds.Tables[0].Rows[0][i].ToString() == "0")
                    {
                        if (ds.Tables[0].Rows[1][i].ToString() == "0")
                        {
                            N00++;
                        }
                    }

                    // N01
                    if (ds.Tables[0].Rows[0][i].ToString() == "1")
                    {
                        if (ds.Tables[0].Rows[1][i].ToString() == "0")
                        {
                            N01++;
                        }
                    }

                    // N10
                    if (ds.Tables[0].Rows[0][i].ToString() == "0")
                    {
                        if ((ds.Tables[0].Rows[1][i].ToString()) !="0")
                        {
                            N10++;
                        }
                    }

                    // N11
                    if (ds.Tables[0].Rows[0][i].ToString() == "1")
                    {
                        if (ds.Tables[0].Rows[1][i].ToString()!="0")
                        {
                            N11++;
                        }
                    }
                }

                //if (a3 == (ssl.Count - 1))
                {
                    //SqlCommand ins = new SqlCommand("update sample set N00=" + N00 + " where KeyWord='" + ri + "'", con);
                    //ins.ExecuteNonQuery();

                    DataRow[] drSelectAll = ds.Tables[0].Select("KeyWord='" + ri + "'");
                    drSelectAll[0]["N00"] = N00;
                    drSelectAll[0]["N01"] = N01;
                    drSelectAll[0]["N10"] = N10;
                    drSelectAll[0]["N11"] = N11;


                    double n = N00 + N11 + N10 + N01;
                    double w1 = Convert.ToDouble((N11 / n) * (Math.Log(((n * N11) / ((N10 + N11) * (N01 + N11))), 2)));
                    double w2 = Convert.ToDouble((N01 / n) * (Math.Log(((n * N01) / (((N01 + N00) * (N01 + N11)))), 2)));
                    double w4 = Convert.ToDouble((N00 / n) * (Math.Log(((n * N00) / (((N00 + N01) * (N00 + N10)))), 2)));
                    double w3 = Convert.ToDouble((N10 / n) * 开发者_JS百科(Math.Log(((n * N10) / (((N10 + N11) * (N00 + N10)))), 2)));
                    if (w1.ToString() == "NaN")
                    {
                        w1 = 0;
                    }
                    if (w2.ToString() == "NaN")
                    {
                        w2 = 0;
                    }
                    if (w3.ToString() == "NaN")
                    {
                        w3 = 0;
                    }
                    if (w4.ToString() == "NaN")
                    {
                        w4 = 0;
                    }

                    double ni = w1 + w2 + w3 + w4;

                    drSelectAll[0]["MI"] = ni;
                    ds.Tables[0].Rows.Add(drSelectAll);
                }

        }
    }


    try
    {

        daSelectAll.Update(ds, "sample");

    }
    catch (Exception)
    {

        throw;//error
    }

Error:Update unable to find TableMapping['sample'] or DataTable 'sample'.


I guess you are missing tablemapping in your code.

Taken from MSDN: "If you do not specify a TableName or a DataTableMapping name when calling the Fill or Update method of the DataAdapter, the DataAdapter will look for a DataTableMapping named "Table". If that DataTableMapping does not exist, the TableName of the DataTable will be "Table". You can specify a default DataTableMapping by creating a DataTableMapping with the name of "Table"."

http://msdn.microsoft.com/en-us/library/ks92fwwh(vs.71).aspx

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜