C#MySql DataTable填入数组

时间:2015-07-10 21:24:22

标签: c# mysql mysqldatareader

我遇到了问题。

我想编写一个程序来将一些内容插入到Mysql数据库中。 在第一次我为数据库中的每个列创建一个自己的String并使用它来进行SQL查询。但在大多数表格中,我有100多列。我不想制作100个变量。所以我决定使用数据表和数组。但现在我不知道如何将列的名称填充到数组中。这是执行该操作的代码的一部分。

        private void button_npccreate_click(object sender, EventArgs e)
    {
        //Umwandlung von C# Variable in Mysql Variable
        MySqlCommand command = new MySqlCommand();
        command.Parameters.AddWithValue("@server", server);
        command.Parameters.AddWithValue("@port", port);
        command.Parameters.AddWithValue("@user", user);
        command.Parameters.AddWithValue("@password", mysqlpassword);
        command.Parameters.AddWithValue("@world", db_world);


        //Connection zu Mysql Server
        string myConnectionString = "Server=" + server + ";Port=" + port + ";Database=" + db_world + ";Uid=" + user + ";Pwd=" + mysqlpassword + ";";
        MySqlConnection connection = new MySqlConnection(myConnectionString);
        MySqlCommand cmd;
        cmd = connection.CreateCommand();
        string readquery = "SELECT * FROM quest_template;";
        MySqlDataAdapter read_adapter = new MySqlDataAdapter(readquery, connection);
        DataTable tableRead = new DataTable();
        connection.Open();
        read_adapter.Fill(tableRead);
        connection.Close();
        int columns = 0;


        if(tableRead.Rows.Count > 0)
        {
        foreach(DataColumn dc in tableRead.Columns)
        {
            columns++;
        }
        }
        else
        {
            MessageBox.Show("The table is empty. Please check your Database.");
        }

        string [] columns_array = new string[columns];
        foreach (DataColumn dc in tableRead.Columns)
        {
// Here i must fill the Array i think. But i dont know how to do                      this.
        }

    }

1 个答案:

答案 0 :(得分:0)

您应该考虑 Emmad Kareem 备注。

您的目标的问题是列可能包含不同类型的值。因此,您无法收集二维数组中的所有单元格(列的一个维度,行的一个维度)。 例如,在下面的代码中,如果要在单个2 dim数组中合并col0Array和col1array,则需要将此数组声明为“object [,]”,这使得与DataTable相比没有优势

int   [] Col0Array = new int   [tableRead.Rows.Count] ; // first Column type is int
string[] Col1Array = new string[tableRead.Rows.Count] ; // second Column type is string
for (int i=0;tableRead.Rows.Count;i++)
{
   Col0Array[i]=(int   )tableRead.Rows[i][0] ;
   Col1Array[i]=(string)tableRead.Rows[i][1] ;
}