我遇到了问题。
我想编写一个程序来将一些内容插入到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.
}
}
答案 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] ;
}