Я пытаюсь создать DataGridView во время выполнения всякий раз, когда нажимаю кнопку. Я также хочу представить данные из таблицы в моей базе данных.
Когда я нажимаю кнопку, которая должна создать DataGridView и показать данные, но она просто ничего не делает. Он не создает DataGridView.
Вот мой код (таблица называется "поставки"):
public partial class managerpage : Form
{
int idWorkersDB = 0;
int idAccountsDB = 1;
int idSuppliersDB = 2;
int idOtherDB = 3;
public static DataGridView workersView = new DataGridView();
public static DataGridView suppliesView = new DataGridView();
public static DataGridView accountsView = new DataGridView();
int clickedID;
private void picBoxSuppliers_MouseUp(object sender, MouseEventArgs e)
{
suppliesView.Location = new Point(59, 51);
suppliesView.Size = new Size(749, 399);
clickedID = idSuppliersDB;
dataDBPanel.Visible = true;
dataDBPanel.Dock = DockStyle.Fill;
titleDataLbl.Text = "Suppliers Data";
titleDataLbl.Left = (this.Width - titleDataLbl.Width) / 2;
OleDbConnection con = new OleDbConnection(@"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=G:\project\FUCKINGVISUALSTUDIOISSOSHIT\loginData.mdb");
OleDbDataAdapter cmd = new OleDbDataAdapter("SELECT * FROM supplies", con);
con.Open();
DataTable tbl = new DataTable();
cmd.Fill(tbl);
con.Close();
suppliesView.DataSource = tbl;
suppliesView.Show();
}
}
Вы скрываете большую часть кода, но я подозреваю, что вы никогда не добавляете в форму этот SuppliesView (представление сетки данных?). Вот пример кода, который прекрасно работает:
void Main()
{
DataTable t = new DataTable();
using (var con = new SqlConnection(@"server=.;Database=Northwind;Trusted_Connection=yes"))
using (var cmd = new SqlCommand(@"select * from Customers", con))
{
con.Open();
t.Load(cmd.ExecuteReader());
con.Close();
}
var f = new Form();
var dgv = new DataGridView { Dock = DockStyle.Fill, DataSource=t};
f.Controls.Add(dgv);
f.Show();
}
Привет :) Это, наконец, работает, и я добавил больше кода, чтобы все немного лучше поняли мою проблему. У меня произошел несчастный случай при написании этого кода, как вы можете видеть, я не добавил «this.control.add(suppliesView)», а также я хотел разместить его на панели, покрывающей весь экран, и когда я создание панели, спрятанной за ней datagridview... Но что действительно решило проблему, так это "this.control.add(suppliesView)", который вы добавили в свой код... Большое спасибо! Вы помогли мне.