0

我有问题。

我想编写一个程序来将一些东西插入 Mysql 数据库。我第一次为数据库中的每一列创建了一个自己的字符串,并用它来制作 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.
        }

    }
4

1 回答 1

0

您应该考虑Emmad Kareem 的言论。

您的目标的问题是列可能包含不同类型的值。因此,您无法收集二维数组中的所有单元格(一维用于列,一维用于行)。例如,在下面的代码中,如果要将 col0Array 和 col1array 合并到一个 2 dim 数组中,则需要将此数组声明为“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] ;
}
于 2015-07-10T21:50:16.023 回答