gpt4 book ai didi

c# - 获取表的列名并将它们存储在字符串或 var c# asp.net 中

转载 作者:太空宇宙 更新时间:2023-11-03 17:17:27 25 4
gpt4 key购买 nike

我想知道如何获取数据库表的列并将它们中的每一个存储在字符串或字符串数​​组中。我有以下代码,但我认为它不起作用。我正在使用 asp.net 中提供的默认表。我已经能够毫无问题地写入此表,但我无法弄清楚如何从中选择并保存检索到的值。这是我后面的代码中的内容

    string connection = ConfigurationManager.ConnectionStrings["ApplicationServices"].ConnectionString;
SqlConnection conn = null;
conn = new SqlConnection(connection);
conn.Open();
using (SqlCommand cmd = new SqlCommand())
{

string query = String.Format("SELECT column_name FROM USER_TAB_COLUMN WHERE table_name = 'TestTable'");
cmd.Connection = conn;
cmd.CommandType = CommandType.Text;
cmd.CommandText = query;
columns.Text = cmd.ExecuteNonQuery().ToString();
conn.Close();
}

错误是无效的对象名称“USER_TAB_COLUMN”。我试过删除它并使用 "SELECT column_name FROM TestTable" 然后它提示 column_name。顺便说一下,Columns 是一个文本框。

最佳答案

您可以使用 DbDateReader.GetSchemaTable .

DataTable schema = null;
using (var con = new MySql.Data.MySqlClient.MySqlConnection(connection))
{
using (var schemaCommand = new MySql.Data.MySqlClient.MySqlCommand("SELECT * FROM TestTable", con))
{
con.Open();
using (var reader = schemaCommand.ExecuteReader(CommandBehavior.SchemaOnly))
{
schema = reader.GetSchemaTable();
}
}
}
foreach (DataRow col in schema.Rows)
{
Console.WriteLine("ColumnName={0}", col.Field<String>("ColumnName"));
}

列名位于每一行的第一列。


I am trying your method but MySql.Data.MySqlClient.MySqlConnection(connection)) is throwing type or namespace could not be found

我可以发誓我见过 MySqlCommandMySqlConnection。所以您正在使用 SQL-Server 作为 rdbms?

using (var con = new SqlConnection(connection))
{
using (var schemaCommand = new SqlCommand("SELECT * FROM TestTable;", con))
{
con.Open();
using (var reader = schemaCommand.ExecuteReader(CommandBehavior.SchemaOnly))
{
schema = reader.GetSchemaTable();
}
}
}
// DataTable part is the same

关于c# - 获取表的列名并将它们存储在字符串或 var c# asp.net 中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17353089/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com