怎样点击新增按键在datagridview中新增一行,并且可以在其中填入新的数据,保存后同步到数据库。
1条回答 默认 最新
- 嗷呜大嘴狼 2023-03-11 10:39关注
在 WinForm 应用程序中,可以使用 DataGridView 控件来显示和编辑数据。可以通过以下步骤来实现在 DataGridView 中点击新增按钮添加新行并保存到数据库中的功能:
添加 DataGridView 控件和新增按钮到窗体上。可以通过 Visual Studio 的设计器来实现。
为新增按钮添加 Click 事件的处理函数。在事件处理函数中,可以通过 DataGridView 的 Rows 属性添加新行。
private void btnAdd_Click(object sender, EventArgs e) { dataGridView.Rows.Add(); }
在 DataGridView 中,可以使用 CellEndEdit 事件来捕获单元格编辑结束的事件,这时可以将修改后的数据同步到数据库中。需要注意的是,DataGridView 中的新增行默认是空行,需要手动判断并过滤掉。
private void dataGridView_CellEndEdit(object sender, DataGridViewCellEventArgs e) { // 只处理非新增行 if (e.RowIndex >= dataGridView.Rows.Count - 1) { return; } // 获取修改后的数据 int id = Convert.ToInt32(dataGridView.Rows[e.RowIndex].Cells["ID"].Value); string name = dataGridView.Rows[e.RowIndex].Cells["Name"].Value.ToString(); // ... // 更新数据库 SqlConnection conn = new SqlConnection("server=localhost;database=mydb;uid=myuser;pwd=mypassword;"); conn.Open(); SqlCommand cmd = new SqlCommand("UPDATE mytable SET Name=@Name WHERE ID=@ID", conn); cmd.Parameters.AddWithValue("@ID", id); cmd.Parameters.AddWithValue("@Name", name); // ... cmd.ExecuteNonQuery(); conn.Close(); }
完整的示例代码如下:
using System; using System.Data.SqlClient; using System.Windows.Forms; namespace DataGridViewExample { public partial class Form1 : Form { public Form1() { InitializeComponent(); } private void Form1_Load(object sender, EventArgs e) { // 初始化 DataGridView 数据 SqlConnection conn = new SqlConnection("server=localhost;database=mydb;uid=myuser;pwd=mypassword;"); conn.Open(); SqlCommand cmd = new SqlCommand("SELECT * FROM mytable", conn); SqlDataReader reader = cmd.ExecuteReader(); while (reader.Read()) { dataGridView.Rows.Add(reader["ID"], reader["Name"], reader["Age"]); } conn.Close(); } private void btnAdd_Click(object sender, EventArgs e) { dataGridView.Rows.Add(); } private void dataGridView_CellEndEdit(object sender, DataGridViewCellEventArgs e) { // 只处理非新增行 if (e.RowIndex >= dataGridView.Rows.Count - 1) { return; } // 获取修改后的数据 int id = Convert.ToInt32(dataGridView.Rows[e.RowIndex].Cells["ID"].Value); string name = dataGridView.Rows[e.RowIndex].Cells["Name"].Value.ToString(); int age = Convert.ToInt32(dataGridView.Rows[e.RowIndex].Cells["Age"].Value); // 更新数据库 SqlConnection conn = new SqlConnection("server=localhost;database=mydb;uid=myuser;pwd=mypassword;"); conn.Open(); SqlCommand cmd = new SqlCommand("UPDATE mytable SET Name=@Name, Age=@Age WHERE ID=@ID", conn); cmd.Parameters.AddWithValue("@ID", id); cmd.Parameters.AddWithValue("@Name", name); cmd.Parameters.AddWithValue("@Age", age); cmd.ExecuteNonQuery(); conn.Close(); } } }
答案出自c# https://www.wodianping.com/
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
- ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
- ¥16 mybatis的代理对象无法通过@Autowired装填
- ¥15 可见光定位matlab仿真
- ¥15 arduino 四自由度机械臂
- ¥15 wordpress 产品图片 GIF 没法显示
- ¥15 求三国群英传pl国战时间的修改方法
- ¥15 matlab代码代写,需写出详细代码,代价私
- ¥15 ROS系统搭建请教(跨境电商用途)
- ¥15 AIC3204的示例代码有吗,想用AIC3204测量血氧,找不到相关的代码。