为了体现面向对象的思想,我们把“增删改查”这些函数封装到一个数据库操作类里;

为了便于窗体程序与数据库之间进行数据交互,我们建一个具有数据库行数据的类,通过它方便的在窗体程序与数据库之间传输数据;

我们新建一个文件夹,把这两个类放在这个文件夹(App)里,以后,把命名空间写上就可以使用这两个类了。

为了便于窗体程序与数据库之间进行数据交互,我们建一个具有数据库行数据的类,通过它方便的在窗体程序与数据库之间传输数据。

首先,建立程序的主窗体

㈠添加数据

当点击“增加”,弹出一个子窗体,通过子窗体往数据库中添加一条数据

private void button1_Click(object sender, EventArgs e)
{
Form5 insert= new Form5();
insert.Owner = this;
insert.Show();
}

子窗体里的函数:

public partial class Form5 : Form
{
public Form5()
{
InitializeComponent();
} private void button1_Click(object sender, EventArgs e)
{
//将文本框中的数据存入SqlData类型的变量udata中
SqlData udata = new SqlData();
udata.Name = textBox1.Text;
udata.Code = textBox2.Text; new SqlDA().addData(udata);//调用添加数据函数,添加数据udata
} }

运行程序,添加数据,查看结果

㈡查询数据

第一个查询形式, 
首先我们需要窗口一加载,就显示出数据库中的所有数据

首先,在存放方法的SqlDA类中,添加一个获取数据的成员方法,该方法能返回一个数据集合

//查询数据的方法
public List<SqlData> select()
{
List<SqlData> list=new List<SqlData>();
//连接数据库,访问数据
_cmd = _con.CreateCommand();
_con.Open();
_cmd.CommandText = "select *from users";
SqlDataReader dr= _cmd.ExecuteReader(); //将数据库数据转换成Sqldata类型,并放入list集合中
while (dr.Read())
{
SqlData data=new SqlData();
data.Code = dr["code"].ToString();
data.Name = dr["name"].ToString();
data.Pwd = dr["pwd"].ToString();
list.Add(data);
}
_con.Close();
return list;
}

然后定义一个绑定数据函数,该函数将上面成员方法返回的数据绑定到listview1中,显示出来

//绑定数据函数
public void bindData(List<SqlData> list)
{
//构建表结构
listView1.Columns.Add("编号");
listView1.Columns.Add("用户名");
listView1.Columns.Add("密码");
//将集合中的数据放入listview1中
foreach (SqlData data in list)
{
ListViewItem it = new ListViewItem();//构建一个listviewitem对象,通过它把数据放入listview1中
it.Text = data.Code;
it.SubItems.Add(data.Name);
it.SubItems.Add(data.Pwd ); listView1.Items.Add(it);//将数据放入listview1的items集合中,
} }

然后窗体加载事件中,追加绑定数据函数的委托

//窗体一加载,在listview1中绑定数据
private void Form4_Load(object sender, EventArgs e)
{
bindData(new SqlDA().select()); }

运行结果

第二个查询形式, 
在窗口中输入用户名,根据用户名进行模糊查询

首先写一个需要参数(用户名)的查询函数,我们可以写一个select的重载函数,如下

//查询数据的方法2,需要一个字符串参数,与上面的函数构成重载
public List<SqlData> select(string uname)
{
List<SqlData> list = new List<SqlData>();
//连接数据库,访问数据
_cmd = _con.CreateCommand();
_con.Open();
_cmd.CommandText = "select *from users where name like '%"+uname+"%'";
SqlDataReader dr = _cmd.ExecuteReader(); //将访问到的数据库数据转换成Sqldata类型,并放入list集合中
while (dr.Read())
{
SqlData data = new SqlData();
data.Code = dr["code"].ToString();
data.Name = dr["name"].ToString();
data.Pwd = dr["pwd"].ToString();
list.Add(data);
}
_con.Close();
return list;
}

点击“查询”按钮

//通过输入用户名,查询数据
private void button4_Click(object sender, EventArgs e)
{
listView1.Items.Clear();
bindData(new SqlDA().select(textBox1.Text));
}

㈢修改数据

首先,将主窗口的FullRowSelect属性设为True,使行数据可选

点击“修改”,弹出以下“修改”子窗体

修改数据不需要修改编号,将“修改”子窗体的第一个文本框的“Enabled”属性设为false。

“修改”子窗体的代码

public partial class Form6 : Form
{ public Form6()
{
InitializeComponent();
}
//重写修改窗口的构造函数,显示选中项的数据
public Form6(SqlData data)
{
InitializeComponent(); textBox3.Text=data.Code;
textBox1.Text=data.Name;
textBox2.Text=data.Pwd; } private void button1_Click(object sender, EventArgs e)
{
//将输入的内容转成SqlData格式
SqlData data = new SqlData();
data.Code = textBox3.Text;
data.Name = textBox1.Text;
data.Pwd = textBox2.Text;
//调用修改数据函数
new SqlDA().update(data);
}
}

修改数据的函数

//修改数据的方法
public void update (SqlData data)
{
//打开连接,拼接命令
_con.Open();
_cmd = _con.CreateCommand();
_cmd.CommandText = "update users set name=@name,pwd=@pwd where code=@code";
_cmd.Parameters.Add("@name",data.Name );
_cmd.Parameters.Add("@pwd", data.Pwd);
_cmd.Parameters.Add("@code", data.Code);
//执行命令,关闭连接
_cmd.ExecuteNonQuery();
_con.Close(); }

将用户名、密码输入后,点击“修改”,在主窗口中点击“查询”,可以看到数据已修改

㈢删除数据

//删除数据的方法
public void delete(SqlData data)
{
//打开连接,拼接命令
_con.Open();
_cmd = _con.CreateCommand();
_cmd.CommandText = "delete from users where code=@code";
_cmd.Parameters.Add("@code", data.Code);
//执行命令,关闭连接
_cmd.ExecuteNonQuery();
_con.Close(); }

C#通过窗体应用程序操作数据库(增删改查)的更多相关文章

  1. 2. MongoDB基本操作 —— 用Mongo.exe操作数据库增删改查

    一.开篇 传统的关系数据库一般由数据库(database).表(table).记录(record)三个层次概念组成,MongoDB是由数据库(database).集合(collection).文档对象 ...

  2. Django-Model操作数据库(增删改查、连表结构)

    一.数据库操作 1.创建model表         基本结构 1 2 3 4 5 6 from django.db import models     class userinfo(models.M ...

  3. phpcms 操作数据库 增删改查

    数据库的其他类继承的都是libs/class/model.class.php 这里面有写好的操作数据库的常用方法 1.增 insert($data, $return_insert_id = false ...

  4. MongoDB学习day04--NodeJs操作数据库增删改查

    一.在Nodejs中使用Mongodb Nodejs需要引入的包 npm install mongodb --save -dev 或者使用镜像 cnpm install mongodb --save ...

  5. java操作数据库增删改查的小工具1--TxQueryRunner

    在java程序中,一般使用jdbc连接数据库,比较麻烦,在看传智教程时学了一个工具类,用于简化与数据库之间的操作步骤,就是TxQueryRunner,他是QueryRunner的子类,用起来和他是一样 ...

  6. JavaWeb学习记录(七)——MVC操作数据库增删改查与分页功能

    一.分页工具类 package blank.util;import java.util.List; import org.springframework.jdbc.core.JdbcTemplate; ...

  7. java操作数据库增删改查的小工具2--TxQueryRunner

    当涉及到多表查询时,如数据库中有两张表分别为t_person和t_address,表结构如下: 其中t_person的外键为t-address的主键aid, 新建两个javaBean类,Person ...

  8. 前端web通过flask操作数据库-增删改查

    后端python代码: #coding:utf8 from flask import Flask,request,render_template import pymysql as mysql imp ...

  9. python操作mysql数据库增删改查的dbutils实例

    python操作mysql数据库增删改查的dbutils实例 # 数据库配置文件 # cat gconf.py #encoding=utf-8 import json # json里面的字典不能用单引 ...

  10. (转)SQLite数据库增删改查操作

    原文:http://www.cnblogs.com/linjiqin/archive/2011/05/26/2059182.html SQLite数据库增删改查操作 一.使用嵌入式关系型SQLite数 ...

随机推荐

  1. 一天一个设计模式——Adapter适配器模式(Wrapper模式)

    一.模式说明 在现实生活中,当需要将两种设备连接起来,但是两个设备的接口规范又不一致(比如电脑上只有Type-C接口,但是你的显示器是HDMI接口),这时候就需要一个适配器,适配器一端连接电脑,一端连 ...

  2. POJ 1006:Biorhythms 中国剩余定理

    Biorhythms Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 121194   Accepted: 38157 Des ...

  3. 连接数据库方法2-DBCP

    DBCP(连接池): 解决对数据库建立以及关闭连接时消耗大量资源的解决方案. 程序创建和关闭对数据库连接时会消耗大量的资源,连接池技术帮我们 在程序运行的开始时就预先创建大量的连接,这些连接组成一个池 ...

  4. vue form 验证

    vue 验证 <Form :model="formModel" label-position="center" :label-width="90 ...

  5. go语言使用

    设置 package control 在 Preferences->Package Setting->Package Control->Settings - User 中加入 cha ...

  6. C#用户控件的使用

    1.添加一个用户控件 2.编辑用户控件,相当于自己定义了一个控件,和其他控件一样在窗体中使用,是一个类. 右击项目,生成一下,就可以看到窗体的工具箱上面多了一组工具,可以看到我们定义的控件login ...

  7. 从Evernote大批顶尖高管离职,看处于漩涡中的笔记应用未来前景

    无论是巨头,还是独角兽,甚至是小而美的某些企业,在发生高管离职.裁员等情况时,总会引起业界的广泛关注.究其原因,就在于高管离职.裁员等往往意味着企业内部发生了动荡,甚至还会直接反映出所在行业的发展趋势 ...

  8. c语言:自增自减运算符的操作详解

    博主在回忆c语言的基本知识时,突然发现自增自减运算符(--.++)这个知识点有些模糊不清,故博主为了给同为小白的同学们提供一些经验,特写下这篇文章. 首先,自增自减运算符共有两种操作方式. 比如,我先 ...

  9. java android环境变量配置

    JAVA_HOME   用于jdk配置D:\Program Files\Java\jdk1.8.0_25 path %JAVA_HOME%\bin;;%JAVA_HOME%\jre\bin;;D:\P ...

  10. Springboot JpaRepository findOne() 方法报错

    用的是springboot2.0,然后XXXRepository.findOne各种报错,各种不行,上网搜都说改回springboot1.5就好了. 这哪行,直接用XXXRepository.find ...