DataGridView:显示数据表,通过此控件中可以实现连接数据库,实现数据的增删改查

一、后台数据绑定:
    
List<xxx> list = new List<xxx>();
      dataGridView1.DataSource = list;
      //设置不自动生成列,此属性在属性面板中没有
      dataGridView1.AutoGenerateColumns = false;
      //取消加载默认选中第一行
      dataGridView1.ClearSelection();

二、前台:
      小三角箭头,取消可编辑,添加,删除功能;
      Columns集合属性中,添加列
      HeaderText中设置显示的文本
      DataPropertyName设置绑定的字段名或数据库列名
      SelectionMode --设置选择方式,FullRowSelect只能选中行
      MultiSelect --是否可以选中多行内容

三、取值:
      取出选中的单元格的值:
      dataGridView1.SelectedCells中放着全部选中的单元格
      if(dataGridView1.SelectedCells.Count > 0)
      {
              MessageBox.Show(dataGridView1.SelectedCells[0].Value.ToString());
      }
      取出选中的行内容:
      if(dataGridView1.SelectedRows.Count > 0)
      {
             MessageBox.Show(dataGridView1.SelectedRows[0].Cells[0].ToString());
      }
      获取用于填充行绑定的对象:
      //行对象使用属性:DataBoundItem
      student sss = dataGridView1.SelectedRows[0].DataBoundItem as student;

四、删除加确认
      MessageBoxButtons btn = MessageBoxButtons.YesNoCancel;
      if (MessageBox.Show("确定要删除么?", "删除数据", btn) == DialogResult.Yes)
      {
      }

五、多条件查询

如果用户什么都不输入,或者文本框是空,这时候是查询所有

//做两个恒成立的条件
           
string tj1 = " 1=1 ";
            string tj2 = " 1=1 ";

//根据用户输入来改变条件
//如果用户输入了姓名
            if (name != "")
            {
                tj1 = " Name like @name ";
            }

//如果用户输入了民族
            if (nation != "")
            {
                tj2 = " Nation = @nation ";
            }

//拼接成完整条件
            string ztj = " where "+tj1+" and "+tj2;

六、例子

通过控件DataGridView,连接数据库(表Student和表Sclass),实现对Student表的增删改查

 代码区:

数据连接类:

namespace WindowsFormsApplication2
{
public class DBConnect
{
private static string connstring = "server=.;database=xuesheng;user=sa;pwd=123";
public static SqlConnection Conn
{
get
{
return new SqlConnection(connstring);
}
}
}
}

DBConnect.cs

实体类:

namespace WindowsFormsApplication2
{
public class Student
{
private string sno; public string Sno
{
get { return sno; }
set { sno = value; }
}
private string sname; public string Sname
{
get { return sname; }
set { sname = value; }
}
private string ssex; public string Ssex
{
get { return ssex; }
set { ssex = value; }
}
private DateTime sbirthday; public DateTime Sbirthday
{
get { return sbirthday; }
set { sbirthday = value; }
}
private string sclass; public string Sclass
{
get { return sclass; }
set { sclass = value; }
}
private string SclassName
{
get
{
SclassDA da = new SclassDA();
return da.SclassName(this.sclass);
}
}
}
}

Student.cs

namespace WindowsFormsApplication2
{
public class Sclass
{
private string cno; public string Cno
{
get { return cno; }
set { cno = value; }
} private string name; public string Name
{
get { return name; }
set { name = value; }
}
}
}

Sclass.cs

数据访问类:

namespace WindowsFormsApplication2
{
public class StudentDA
{
private SqlConnection _conn;
private SqlCommand _cmd;
private SqlDataReader _dr;
public StudentDA()
{
_conn = DBConnect.Conn;
_cmd = _conn.CreateCommand();
}
//查询
public List<Student> Select()
{
List<Student> list = new List<Student>();
_cmd.CommandText = "select * from Student";
_conn.Open(); _dr = _cmd.ExecuteReader(); if (_dr.HasRows)
{
while (_dr.Read())
{
Student data = new Student();
data.Sno = _dr[].ToString();
data.Sname= _dr[].ToString();
data.Ssex = _dr[].ToString();
data.Sbirthday =Convert.ToDateTime( _dr[]);
data.Sclass = _dr[].ToString(); list.Add(data);
}
}
_conn.Close(); return list;
}
public Student Select(string sno)
{ _cmd.CommandText = "select * from Student where Sno=@sno";
_cmd.Parameters.Clear();
_cmd.Parameters.AddWithValue("@sno",sno);
_conn.Open(); _dr = _cmd.ExecuteReader();
Student data = new Student();
if (_dr.HasRows)
{
_dr.Read();
data.Sno = _dr[].ToString();
data.Sname = _dr[].ToString();
data.Ssex = _dr[].ToString();
data.Sbirthday = Convert.ToDateTime(_dr[]);
data.Sclass = _dr[].ToString();
}
_conn.Close(); return data;
}
//删除
public void Delete(string sno)
{
_cmd.CommandText = "delete from Student where Sno=@sno";
_cmd.Parameters.Clear();
_cmd.Parameters.AddWithValue("@sno",sno);
_conn.Open();
_cmd.ExecuteNonQuery();
_conn.Close();
}
//多条件查询
public List<Student> Select(string sname,string sclass)
{
//做两个恒等条件
string tj1 = " 1=1 ";
string tj2 = " 1=1 ";
//根据用户输入改变条件
//用户输入了姓名
if(sname !="")
{
tj1 = " Sname like @sname ";
}
//用户输入了班级
if(sclass !="")
{
tj2 = " Class = @sclass ";
}
//拼接成完整的条件
string tj = " where " + tj1 + " and " + tj2;
List<Student> list = new List<Student>();
_cmd.CommandText = "select * from Student"+tj;
_cmd.Parameters.Clear();
_cmd.Parameters.AddWithValue("@sname","%"+sname+"%");
_cmd.Parameters.AddWithValue("@sclass",sclass);
_conn.Open(); _dr = _cmd.ExecuteReader(); if (_dr.HasRows)
{
while (_dr.Read())
{
Student data = new Student();
data.Sno = _dr[].ToString();
data.Sname = _dr[].ToString();
data.Ssex = _dr[].ToString();
data.Sbirthday = Convert.ToDateTime(_dr[]);
data.Sclass = _dr[].ToString(); list.Add(data);
}
}
_conn.Close(); return list;
}
//修改
public void Update(string sno, string sname, string ssex, DateTime sbirthday,string sclass)
{
_cmd.CommandText = "update Student set Sname=@sname,Ssex=@ssex,Sbirthday=@sbirthday,Class=@sclass where Sno = @sno";
_cmd.Parameters.Clear();
_cmd.Parameters.AddWithValue("@sno", sno);
_cmd.Parameters.AddWithValue("@sname", sname);
_cmd.Parameters.AddWithValue("@ssex", ssex);
_cmd.Parameters.AddWithValue("@sbirthday", sbirthday);
_cmd.Parameters.AddWithValue("@sclass", sclass); _conn.Open();
_cmd.ExecuteNonQuery();
_conn.Close();
}
//添加
public bool Add(string sno, string sname,string ssex,DateTime sbirthday,string sclass)
{
_cmd.CommandText = "insert into Student values(@sno,@sname,@ssex,@sbirthday,@sclass)";
_cmd.Parameters.Clear();
_cmd.Parameters.AddWithValue("@sno", sno);
_cmd.Parameters.AddWithValue("@sname", sname);
_cmd.Parameters.AddWithValue("@ssex", ssex);
_cmd.Parameters.AddWithValue("@sbirthday", sbirthday);
_cmd.Parameters.AddWithValue("@sclass", sclass); _conn.Open();
int n = _cmd.ExecuteNonQuery();
_conn.Close(); if (n > )
{
return true;
}
else
{
return false;
}
} }
}

StudentDA.cs

namespace WindowsFormsApplication2
{
public class SclassDA
{
private SqlConnection _conn;
private SqlCommand _cmd;
private SqlDataReader _dr;
public SclassDA()
{
_conn = DBConnect.Conn;
_cmd = _conn.CreateCommand();
}
public List<Sclass> Select()
{
List<Sclass> list = new List<Sclass>();
_cmd.CommandText = "select * from Sclass";
_conn.Open(); _dr = _cmd.ExecuteReader(); if (_dr.HasRows)
{
while (_dr.Read())
{
Sclass data = new Sclass();
data.Cno = _dr[].ToString();
data.Name= _dr[].ToString();
list.Add(data);
}
}
_conn.Close(); return list;
}
public string SclassName(string cno)
{
string name = "";
_cmd.CommandText = "select Name from Sclass where Cno=@cno";
_cmd.Parameters.AddWithValue("@cno", cno); _conn.Open(); _dr = _cmd.ExecuteReader(); if (_dr.HasRows)
{
_dr.Read();
name = _dr[].ToString();
} _conn.Close();
return name;
}
}
}

SclassDA.cs

主窗体:

namespace WindowsFormsApplication2
{
public partial class Form1 : Form
{
public static int bs = ;
public Form1()
{
InitializeComponent();
} private void Form1_Load(object sender, EventArgs e)
{
StudentDA da = new StudentDA();
//绑定数据源
dataGridView1.DataSource = da.Select();
//取消自动显示列
dataGridView1.AutoGenerateColumns = false; //取消选中第一行
dataGridView1.ClearSelection();
//给下拉列表绑定值
SclassDA nda = new SclassDA();
cmbbanji.DataSource = nda.Select();
cmbbanji.DisplayMember = "Name";
cmbbanji.ValueMember = "Cno";
} //删除
private void txtshan_Click(object sender, EventArgs e)
{
MessageBoxButtons btn = MessageBoxButtons.YesNoCancel;
if (MessageBox.Show("确定要删除么?", "删除数据", btn) == DialogResult.Yes)
{
//取出选中行里面绑定的对象
Student data = dataGridView1.SelectedRows[].DataBoundItem as Student; StudentDA da = new StudentDA();
da.Delete(data.Sno);
dataGridView1.DataSource = da.Select();
}
} //修改
private void txtxiu_Click(object sender, EventArgs e)
{
if (dataGridView1.SelectedRows.Count > )
{
//取出选中项的主键值
Student data = dataGridView1.SelectedRows[].DataBoundItem as Student;
//打出修改窗体
XiuGai xg = XiuGai.NewXiuGai(data.Sno);
//显示窗体
xg.Show();
//xg.Owner = this;
//让修改窗体获得焦点
xg.Focus();
}
else
{
MessageBox.Show("没有选中任何项!");
}
} //查询
private void txtcha_Click(object sender, EventArgs e)
{
//取数据
string sname = txtxing.Text;
string sclass = cmbbanji.SelectedValue.ToString();
//根据条件查询,结果交给datagirdview显示
StudentDA da = new StudentDA();
dataGridView1.DataSource = da.Select(sname,sclass);
dataGridView1.AutoGenerateColumns = false;
} //时钟工具间隔执行的事件,刷新主窗体
private void timer1_Tick(object sender, EventArgs e)
{
if (bs == )
{
StudentDA da = new StudentDA();
dataGridView1.DataSource = da.Select();
bs = ;
}
//if (Convert.ToInt32(this.Tag) == 1)
//{
// StudentDA da = new StudentDA();
// dataGridView1.DataSource = da.Select();
// this.Tag = 0;
//} } //添加
private void txttian_Click(object sender, EventArgs e)
{ //打出修改窗体
XiuGai xg = new XiuGai();
//显示窗体
xg.Show();
//xg.Owner = this;
//让修改窗体获得焦点
xg.Focus();
}
}
}

Form1.cs

修改添加窗体:

namespace WindowsFormsApplication2
{
public partial class XiuGai : Form
{
//用来存储传递过来的主键值
private string Sno = "";
//用来存储该类的对象
private static XiuGai xg = null;
public XiuGai()
{
InitializeComponent();
}
public XiuGai(string sno)
{
InitializeComponent();
this.Sno = sno;
} private void XiuGai_Load(object sender, EventArgs e)
{
if (Sno != "")
{
txtsno.ReadOnly = true;
//给下拉列表绑定值
SclassDA nda = new SclassDA();
cmbsclass.DataSource = nda.Select();
cmbsclass.DisplayMember = "Name";
cmbsclass.ValueMember = "Cno";
//对界面内容进行初始化
StudentDA da = new StudentDA();
Student data = da.Select(Sno);
txtsno.Text = data.Sno;
txtsname.Text = data.Sname;
bool sex = (data.Ssex == "男" ? true : false);
rdnan.Checked = sex;
rdnv.Checked = !sex; txtsbirthday.Text = data.Sbirthday.ToString("yyyy-MM-dd HH:mm:ss");
}
else
{
SclassDA nda = new SclassDA();
cmbsclass.DataSource = nda.Select();
cmbsclass.DisplayMember = "Name";
cmbsclass.ValueMember = "Cno";
} }
//返回对象的方法
public static XiuGai NewXiuGai(string sno)
{
if (xg == null || xg.IsDisposed)
{
xg = new XiuGai(sno);
} return xg;
} //修改
private void button1_Click(object sender, EventArgs e)
{
//获取数据
string _sno = txtsno.Text;
string _sname = txtsname.Text;
string _ssex=(rdnan.Checked==true?"男":"女");
DateTime _sbirthday = Convert.ToDateTime(txtsbirthday.Text);
string _sclass = cmbsclass.SelectedValue.ToString(); StudentDA ida = new StudentDA();
ida.Update(_sno, _sname, _ssex, _sbirthday, _sclass); //this.Owner.Tag = 1;
//给Form1的成员变量bs赋值
Form1.bs = ;
this.Close();
} //查询
private void button2_Click(object sender, EventArgs e)
{
string _sno = txtsno.Text;
string _sname = txtsname.Text;
string _ssex = (rdnan.Checked == true ? "男" : "女");
DateTime _sbirthday = Convert.ToDateTime(txtsbirthday.Text);
string _sclass = cmbsclass.SelectedValue.ToString(); StudentDA ida = new StudentDA();
ida.Add(_sno, _sname, _ssex, _sbirthday, _sclass); //this.Owner.Tag = 1;
Form1.bs = ;
this.Close();
}
}
}

XiuGai.cs

效果显示区:

主窗体:

删除:

添加:

修改:

查询:

※数据区别显示

//遍历datagridview里面行的集合,取出每一个行

foreach (DataGridViewRow row in dataGridView1.Rows)

{

//将该行里面绑定的数据项取出

Info data = row.DataBoundItem as Info;

//判断是不是男女

if (data.Sex)
{
}
}

winform窗体(六)——DataGridView控件及通过此控件中实现增删改查的更多相关文章

  1. Winform(DataGridView)控件及通过此控件中实现增删改查

    DataGridView:显示数据表,通过此控件中可以实现连接数据库,实现数据的增删改查 一.后台数据绑定:    List<xxx> list = new List<xxx> ...

  2. DataGridView中进行增删改查

    首先我们需要知道是在哪个数据库中的哪个表进行增删改查: 这就需要我们: 建立给连接服务器的类:(可以在方法类中建立) 建立一个对列名进行封装的类:方便数据之间的传接:(学到Linq-sql时这些就简便 ...

  3. WinForm DataGridView增删改查

    DataGridView连接数据库对表进行增删改查 一.绑定数据源 //做一个变量控制页面刷新 ; public Form1() { InitializeComponent(); } private ...

  4. winform 窗体实现增删改查(CRUD)共用模式

    转载:http://www.csframework.com/archive/2/arc-2-20110617-1632.htm 高度封装的编辑窗体 http://www.cnblogs.com/wuh ...

  5. C#winform窗口登录和数据的增删改查

    工具:VS2013 数据库SqlServer2008 两张表,一个用户登录表,一个资料表用于增删改查 .先把表建好.可以根据我发的图建立,这样下面的代码修改的就少. 资料部分SQL CREATE TA ...

  6. datagridview数据绑定操作数据库实现增删改查

    DataSet数据集,数据缓存在客户端内存中,支持断开式连接.DataGridView控件绑定DataSet时,它自动的改变的DS的行的状态,而且在做增删改查的时候,可以借助SqlCommandBui ...

  7. c#操作数据库的增删改查语句及DataGridView简单使用

    下面是要用户名和密码连接数据库的操作: 一.定义连接字符串,用来链接SQL Server string str_con = "server=.(服务器名称一般为 . );database=W ...

  8. 使用DataGridView进行增删改查,并同步到数据库

    DataGridView控件具有极高的可配置性和可扩展性.它提供有大量的属性.方法和事件,能够用来对该控件的外观和行为进行自己定义.以下通过一个小样例来展示DataGridView进行增删改查,并同步 ...

  9. C#在winform中操作数据库,实现数据增删改查

    1.前言: 运行环境:VS2013+SQL2008+Windows10 程序界面预览: 使用的主要控件:dataGridview和menuStrip等. 2.功能具体介绍: 1.首先,我们要先实现基本 ...

随机推荐

  1. java 开发中经常问到得懒汉模式 (单利模式)

    //懒汉模式 class Single { public static Single s = null; public Single (){} public static Single getInst ...

  2. 【LeetCode】Counting Bits(338)

    1. Description Given a non negative integer number num. For every numbers i in the range 0 ≤ i ≤ num ...

  3. Java多线程学习笔记

    进程:正在执行中的程序,其实是应用程序在内存中运行的那片空间.(只负责空间分配) 线程:进程中的一个执行单元,负责进程汇总的程序的运行,一个进程当中至少要有一个线程. 多线程:一个进程中时可以有多个线 ...

  4. 开源服务专题之------ssh防止暴力破解及fail2ban的使用方法

    15年出现的JAVA反序列化漏洞,另一个是redis配置不当导致机器入侵.只要redis是用root启动的并且未授权的话,就可以通过set方式直接写入一个authorized_keys到系统的/roo ...

  5. Windows下80端口被pid为4的System进程占用解决方法

    前言 之前是Windows 7系统,前段时间装了Windows 10,php环境还没来得及搭建.今天折腾了一下,是用nginx+php,端口是80(已经停止了iis服务),nginx就是起不来,十之八 ...

  6. @Html.Raw显示一张图片

    在ASP.NET MVC中,显示一张图片,是很方便的事情,完全可以在控制器中组合html代码,并传给视图. 下面一个简单的例子: public ActionResult HtmlRawImage() ...

  7. WebApi设置SessionState为Required

    public override void Init() { //在注册管道事件中 require session state //只能在引发“HttpApplication.AcquireReques ...

  8. Redis 学习笔记(C#)

    Redis安装及简单操作 Windows下安装步骤: 1. 第一步当然是先下载咯~  地址:https://github.com/dmajkic/redis/downloads (根据自己实际情况选择 ...

  9. 【夯实PHP基础】PHP 面向对象

    1. 对象中的属性或者函数是 private 或者是 protect的时候,当实例化这个对象的时候,外部是不能访问到这个属性和函数的. <?php class TestClass { //pri ...

  10. gif jpg bmp png的区别

    PNG格式图片因其高保真性.透明性及文件大小较小等特性,被广泛应用于网页设计.平面设计中.网络通讯中因受带宽制约,在保证图片清晰.逼真的前提下,网页中不可能大范围的使用文件较大的bmp.jpg格式文件 ...