Winform开发之DataGridView的增删改
DataGridView是一个非常强大的控件,用法很多。这里介绍一个简单的增删改例子。
贴效果图

右侧输入学生信息点击新增,将数据增加到数据库,并且加载到datagridview中,点击选择某条数据修改,将选择的数据加载到右侧的编辑框内,修改后点击修改即可,也可直接删除。
贴代码
public partial class Form1 : Form
{ private static string strConn = "Data Source=210.26.*.*;Initial Catalog=Test;User ID=sa;Password=****";
private SqlConnection conn = new SqlConnection(strConn);
private string sqlId = "";
private SqlCommand cmd = null;
private SqlDataAdapter da = null; public Form1()
{
InitializeComponent();
} private void Form1_Load(object sender, EventArgs e)
{
//SqlDataReader studentlist = cmd.ExecuteReader();
//bindingSource1.DataSource = studentlist;
//dataGridView1.DataSource = bindingSource1;
BindData();
}
private void BindData()
{
if (conn.State == ConnectionState.Closed)
{
conn.Open();
}
sqlId = "select * from [Student] ";
cmd = new SqlCommand(sqlId, conn);
da = new SqlDataAdapter(cmd);
DataSet ds = new DataSet();
da.Fill(ds, "student");
dataGridView1.AutoGenerateColumns = false;//此行指定不需要自动绑定数据列,数据列在dataGridView的属性items集合里指定,必须放在绑定数据之前哦,放到后面是没用的
//dataGridView1.DataSource=ds.Tables["Student"];此处直接用DataTalbe绑定,与下面两行代码的效果是一样的
dataGridView1.DataSource = ds;//使用Dataset,单必须指定DataMember,因为DataSet是DataTable的集合,而datagridview只能绑定一个datatable
dataGridView1.DataMember = "Student";
if (conn.State == ConnectionState.Open)
{
conn.Close();
}
} private void btnAdd_Click(object sender, EventArgs e)
{
try
{
string username = textBox1.Text;
string homeaddress = textBox2.Text;
string info = textBox3.Text;
conn.Open();
//准备一个SQL语句,其中以@开头的在这里只表示一种变量,一种参数。
sqlId = "Insert into Student(StudenTnAME, HomeAddress, Content)values(@StudenTnAME,@HomeAddress,@Content)";
//创建一个参数数组,并且用花括号里面的值来初始化数组
SqlParameter[] parameters = new[]
{
//这里也有个初始化的过程,将name复制给@name,下面的是一样的
new SqlParameter("@StudenTnAME",username),//而小括号右边的name就是程序一开始我们得到的用户输入的值
new SqlParameter("@HomeAddress",homeaddress),
new SqlParameter("@Content",info)
};
cmd=conn.CreateCommand();
//利用对象的属性,把sql字符串放进命令(设置要对数据源执行的SQL语句)
cmd.CommandText = sqlId;
//先利用对象的Parameters属性获取参数集,再将参数集的值附加到后面
cmd.Parameters.AddRange(parameters);
int x=cmd.ExecuteNonQuery();
if (x ==)
{
//如果添加成功,那么给用户提示一下
MessageBox.Show("添加成功");
textBox1.Text = "";
textBox2.Text = "";
textBox3.Text = "";
} }
catch(Exception ex)
{
MessageBox.Show(ex.Message);
}
finally
{
conn.Close();
}
} //点击选中行,将内容放到编辑框内
private void dataGridView1_CellClick(object sender, DataGridViewCellEventArgs e)
{
textBox1.Text = dataGridView1.Rows[e.RowIndex].Cells["studentname"].Value.ToString();
textBox2.Text = dataGridView1.Rows[e.RowIndex].Cells["homeaddress"].Value.ToString();
textBox3.Text = dataGridView1.Rows[e.RowIndex].Cells["info"].Value.ToString();
} //对修改该内容进行保存
private void btnUpdate_Click(object sender, EventArgs e)
{
try
{
conn.Open();
//准备一个SQL语句,拼接一个sql串,这里有别于ADD里面传参
sqlId = "update Student set StudenTnAME='" + textBox1.Text + "',HomeAddress='" + textBox2.Text + "',Content='" + textBox3.Text + "' where ID=" + Convert.ToInt32(dataGridView1.CurrentRow.Cells[].Value.ToString()); cmd = conn.CreateCommand();
//利用对象的属性,把sql字符串放进命令(设置要对数据源执行的SQL语句)
cmd.CommandText = sqlId; int x = cmd.ExecuteNonQuery();
if (x == )
{
//如果添加成功,那么给用户提示一下
MessageBox.Show("修改成功");
textBox1.Text = "";
textBox2.Text = "";
textBox3.Text = "";
BindData();
}
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
finally
{
conn.Close();
}
}
//删除选中行
private void btnDel_Click(object sender, EventArgs e)
{
try
{
conn.Open();
//准备一个SQL语句,拼接一个sql串,这里有别于ADD里面传参
sqlId = " delete from Student where ID=" +Convert.ToInt32(dataGridView1.CurrentRow.Cells[].Value.ToString()); cmd = conn.CreateCommand();
//利用对象的属性,把sql字符串放进命令(设置要对数据源执行的SQL语句)
cmd.CommandText = sqlId; int x = cmd.ExecuteNonQuery();
if (x == )
{
//如果添加成功,那么给用户提示一下
MessageBox.Show("删除成功");
textBox1.Text = "";
textBox2.Text = "";
textBox3.Text = "";
BindData();
}
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
finally
{
conn.Close();
}
} }
就是这么简单,但是我们可以看到数据的操作是比较繁琐的,后面的博文会封装一个数据库操作类,进行操作。
Winform开发之DataGridView的增删改的更多相关文章
- Winform开发之DataGridView事件和属性
DataDridView的事件和属性非常多,一一介绍还是不现实,这里借鉴一下园友和MSDN上的介绍吧 1.C#中 DataGridView 属性说明(转载) 2.MSDN上DataGridView事件 ...
- 安卓开发之sql语句增删改查2(利用谷歌封装好的API进行增删改查)
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android=&quo ...
- 安卓开发之sql语句增删改查
package com.lidaochen.phonecall; import android.content.Context; import android.database.sqlite.SQLi ...
- 使用DataGridView进行增删改查,并同步到数据库
DataGridView控件具有极高的可配置性和可扩展性.它提供有大量的属性.方法和事件,能够用来对该控件的外观和行为进行自己定义.以下通过一个小样例来展示DataGridView进行增删改查,并同步 ...
- 浅谈dataGridView使用,以及画面布局使用属性,对datagridview进行增删改查操作,以及委托使用技巧
通过几天的努力后,对datagridview使用作一些简要的介绍,该实例主要运用与通过对datagridview操作.对数据进行增删改查操作时,进行逻辑判断执行相关操作.简单的使用委托功能,实 ...
- Winform开发之SqlCommand常用属性和方法
SqlCommand类表示要对 SQL Server 数据库执行的一个 Transact-SQL 语句或存储过程,有若干个属性和若干个方法,具体的各类方法使用可以从msdn上找到. 这里介绍几个常用东 ...
- winform开发之UI系列
1.如何构造一个漂亮的主窗体 主要讲述如何对一个新建窗体的美化过程,涉及到经常需要用到的几个属性我会着重强调它的用法,并不断更新它,因为楼主也正在探索中.... 步骤如下: vs新建一个winform ...
- winform 开发之Control.InvokeRequired
Control.InvokeRequired 获取一个值,该值指示调用方在对控件进行方法调用时是否必须调用 Invoke 方法,因为调用方位于创建控件所在的线程以外的线程中. InvokeRequir ...
- 对datagridview进行增删改(B)
create DATABASE stu ON ( name='stu.mdf', filename='F:\胡浴东\数据库\stu数据库\stu.mdf', size=, filegrowth= ) ...
随机推荐
- python学习之路-day10
一.什么是线程 在传统操作系统中,每个进程有一个地址空间,而且默认就有一个控制线程. 线程顾名思义,就是一条流水线工作的过程,一条流水线必须属于一个车间,一个车间的工作过程是一个进程. 车间负责把资源 ...
- Spring MVC同一方法返回JSON/XML格式
最近一道面试题,要求同一API接口支持不同格式返回值.一开始是设想通过过滤器(Filter)设置返回值,但是并不可行,因为方法返回值一般都是类型需要做转换,而过滤器则是前置的.另一方面可以通过拦截器的 ...
- 浅谈JS严格模式
浅谈JS严格模式 简介 何为严格模式?严格模式(strict mode)即在严格的条件下运行,在严格模式下,很多正常情况下不会报错的问题语句,将会报错并阻止运行. 但是,严格模式可以显著提高代码的健壮 ...
- JavaScript 预编译(变量提升和函数提升的原理)
本文部分内容转自https://www.cnblogs.com/CBDoctor/p/3745246.html 1.变量提升 console.log(global); // undefined var ...
- 参考sectools,每个人至少查找5种安全工具、库等信息并深入研究至少两种并写出使用教程
1.Nessus Nessus是免费网络漏洞扫描器,它可以运行于几乎所有的UNIX平台之上.它不仅能永久升级,还免费提供多达11000种插件(但需要注册并接受EULA-acceptance--终端用户 ...
- 20155201 2016-2017-2 《Java程序设计》第十周学习总结
20155201 2016-2017-2 <Java程序设计>第十周学习总结 教材学习内容总结 Java密码技术 安全的三个属性 机密性 完整性 可用性 密码学: 主要是研究保密通信和信息 ...
- POJ 3660 Cow ContestCow(Floyd传递闭包)题解
题意:给出m个关系,问你能确定机头牛的排名 思路:要确定排名那必须要把他和其他n-1头牛比过才行,所以Floyd传递闭包,如果赢的+输的有n-1就能确定排名. 代码: #include<cstd ...
- linux开启nscd服务缓存加速
在我使用的阿里云主机上有观察到开启了一个服务nscd ,后来谷哥了下该服务的作用.了解到nscd会缓存三种服务passwd group hosts,所以它会记录三个库,分别对应源/etc/passwd ...
- [经验分享]SecureCRT导出操作日志 + Notepad自定义语言格式高亮日志文件
起因及效果展示 最近使用CRT,有些命令会输出很多内容,这时如果你想要得知输出内容是从哪里开始的,很容易被大量的同种颜色的文字搞的晕头转向.如果输入的命令是不同的颜色,这会大大得帮助我们. 所谓的命令 ...
- 解决 vim 乱码
打开vim安装目录下的_vimrc,在头部加上几句配置语句就能搞定: //设置默认编码 set encoding=utf-8 set fileencodings=utf-8,chinese,latin ...