今天总结了一下ADO.NET编程中DataReader和dataSet两个比较重要的对象的使用,完成了combobox,listbox,以及fpSpread动态添加数据的测试,对使用sqlCommand来添加SQL语句参数也有了一定的认识,希望分朋友们分享一下经验,当然也有不足,工作不忙的时候再好好修改~

1.首先MS SQL Server 2012 Management在本机创建的数据库test,另外两个表,部门表和员工表

2.winform编写,form1添加4个控件:button2,listBox1,comboBox1,fpSpread_yuangong然后进行编程

<没用定义新的类,有兴趣的朋友可以定义DBconnection这样的类,DB连接,字段等属性封装进去>最不能容忍的是公司限网连截图都不能上传,有时间再编辑

代码如下:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Collections;
using System.Data.SqlClient;
using FarPoint.Win.Spread; namespace WindowsFormsApp_DB
{
public partial class Form1 : Form
{ public static string dbconnstring = "server=Q1502LP0003\\SQLEXPRESS;database=test;uid=ammy;pwd=ammy714926;";
//SqlConnection dbc = new SqlConnection("server=Q1502LP0003\\SQLEXPRESS;database=test;uid=ammy;pwd=ammy714926;"); public SqlDbType sqlDbType { get; set; } public Form1()
{
InitializeComponent();
} private void button2_Click(object sender, EventArgs e)
{
listBox1.Items.Clear();//每次清空
SqlConnection dbc = new SqlConnection(dbconnstring);
string sQuery = "";
sQuery = "SELECT ";
sQuery = sQuery + "* ";
sQuery = sQuery + "FROM test.dbo.部门表 WITH(NOLOCK)";
SqlCommand dbm = new SqlCommand(sQuery, dbc);
dbc.Open();//连接到数据源
SqlDataReader dbReader = dbm.ExecuteReader(CommandBehavior.CloseConnection);
while(dbReader.Read())
{
//必须和DB表列名一致,或者用索引
listBox1.Items.Add("部门编号是:"+dbReader["部门编号"].ToString().Trim());
listBox1.Items.Add("部门名称是:" + dbReader["部门名称"].ToString().Trim());
listBox1.Items.Add("部门职责是:" + dbReader["部门职责"].ToString().Trim());
listBox1.Items.Add("-----------------------------"); }
dbReader.Close();
dbc.Dispose();
dbc.Close();//关闭数据源连接,因为SqlDataReader始终占有SqlConnection,需要在用完关闭
dbc = null;
} private void Form1_Load(object sender, EventArgs e)
{
initial(fpSpread_yuangong);
setcombox(comboBox1);
//属性设计器里:this.comboBox1.DropDownStyle = System.Windows.Forms.ComboBoxStyle.DropDownList;
} private void initial(FpSpread spread)
{
spread.Sheets[].ColumnCount = ;
spread.Sheets[].ColumnHeader.Rows[].Height = ;
spread.Sheets[].ColumnHeader.Cells[, ].Text = "员工编号";
spread.Sheets[].ColumnHeader.Cells[, ].Text = "员工姓名";
spread.Sheets[].ColumnHeader.Cells[, ].Text = "联系电话";
spread.Sheets[].ColumnHeader.Cells[, ].Text = "email";
spread.Sheets[].Columns[].Width = ;
spread.Sheets[].Columns[].Width = ;
spread.Sheets[].Columns[].Width = ;
spread.Sheets[].Columns[].Width = ; } private void setcombox(ComboBox comboBox)
{
SqlConnection dbc = new SqlConnection(dbconnstring);
string sQuery1 = "";
sQuery1 = "select * from test.dbo.部门表";
//sQuery1 = "select top 2 * from test.dbo.部门表";由此可见加载到dataset的数据不是整张表,而是由select决定的数据集
SqlCommand dbm1 = new SqlCommand(sQuery1,dbc);
SqlDataAdapter adapter = new SqlDataAdapter();
dbc.Open();
adapter.SelectCommand = dbm1;
DataSet ds = new DataSet();
DataTable bumen = ds.Tables.Add("内存部门表");
adapter.Fill(bumen); dbc.Dispose();
dbc.Close();//关闭数据源连接
dbc = null; DataRow dr = bumen.NewRow();
dr["部门编号"] = "";
dr["部门名称"] = "全体";
bumen.Rows.InsertAt(dr, ); comboBox.ValueMember = "部门编号";
comboBox.DisplayMember = "部门名称";
comboBox.DataSource = bumen; } private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)
{
searchStuff();
} private void searchStuff()
{
string paraziduan = comboBox1.SelectedValue.ToString();
string sQuery2 = "";
if (paraziduan == "")//这里不是paraziduan == "全体"!这是显示的数据!所以调试了好久才发现!
{
sQuery2 = "select * from test.dbo.员工通讯录表";
}
else
{
sQuery2 = sQuery2 + "select * from test.dbo.员工通讯录表 where 所属部门 = @dbpara";
//sQuery2 = sQuery2 + "select * from test.dbo.员工通讯录表where 所属部门"+para+"";这样写的话总是错,这种格式不知道错在哪里
} SqlConnection dbc = new SqlConnection(dbconnstring);
if (dbc.State.Equals(ConnectionState.Closed))
{
dbc.Open();
} //以下是利用SqlCommand传参数的方法,很好用!
SqlCommand dbm2 = new SqlCommand(sQuery2,dbc);
dbm2.CommandText = sQuery2;
SqlParameter para = new SqlParameter("@dbpara", SqlDbType.VarChar, );//生成一个名字为@dbpara的参数,字段数据类型和长度要和DB表字段设置一致
para.Value = paraziduan;//给参数赋值
dbm2.Parameters.Add(para); SqlDataAdapter adapter2 = new SqlDataAdapter();
adapter2.SelectCommand = dbm2;
DataSet ds2 = new DataSet();
DataTable yuangong = ds2.Tables.Add("员工按部门选择表");
adapter2.Fill(yuangong); dbc.Dispose();
dbc.Close();//关闭数据源连接
dbc = null; fpSpread_yuangong.DataSource = yuangong;
for (int i = ; i < yuangong.Rows.Count; i++)
{
fpSpread_yuangong.Sheets[].ColumnCount = ;//如果注释这行,奇怪的是会把dataTable的所以字段无差别全部显示?
fpSpread_yuangong.Sheets[].Cells[i, ].Text = yuangong.Rows[i]["员工编号"].ToString();
fpSpread_yuangong.Sheets[].Cells[i, ].Text = yuangong.Rows[i]["姓名"].ToString();
fpSpread_yuangong.Sheets[].Cells[i, ].Text = yuangong.Rows[i]["电话号码"].ToString();
//搞不清电子邮件一列为什么显示不出来?
fpSpread_yuangong.Sheets[].Cells[i, ].Text = yuangong.Rows[i]["电子邮件"].ToString().Trim();
} } }
}

效果图:

是今天业余学习的小结。对于DataReader和dataSet的区别,网上一搜就是一大堆,关键还是要理解和运用!

加油!

ADO.NET_包括DataReader和dataSet的使用的更多相关文章

  1. C#中对象,字符串,dataTable、DataReader、DataSet,对象集合转换成Json字符串方法。

    C#中对象,字符串,dataTable.DataReader.DataSet,对象集合转换成Json字符串方法. public class ConvertJson { #region 私有方法 /// ...

  2. Data Base sqlServer DataReader与DataSet的区别

    sqlServer   DataReader与DataSet的区别 从以下这几个方面比较: 1.与数据库连接: DataReader:面向连接,只读,只进,只能向前读,读完数据就断开连接: DataS ...

  3. DataReader 和 DataSet 的区别

    摘自:http://www.cnblogs.com/zhjjNo1/archive/2009/08/26/1554420.html 第一种解释 DataReader和DataSet最大的区别在于,Da ...

  4. DataReader和DataSet的区别以及使用

    DataReader和DataSet这两个对象都可以将检索的关系数据存储在内存中.它们在功能使用方面非常相似,但是它们不可以相互替换. 主要区别如表所示:   DataReader DataSet 数 ...

  5. DataReader和DataSet区别

    可以使用DataReader类的对象或DataSet类的对象从数据库读取数据,但它们是有区别的,归纳起来大致有以下几条: 1.       DataReader是数据管理提供者类,而DataSet是一 ...

  6. sqlServer DataReader与DataSet的区别

    sqlServer   DataReader与DataSet的区别 从以下这几个方面比较: 1.与数据库连接: DataReader:面向连接,只读,只进,只能向前读,读完数据就断开连接: DataS ...

  7. datareader 和dataset 区别

    ADO.NET2.0提供了两个用于检索关系数据的对象:DataSet和DataReader.并且这两个对象都可以将检索的关系数据存储在内存中.在软件开发过程中经常用到这两个控件,由于这两个控件在使用和 ...

  8. 30、ADO.NET、事务、DataSet

    ADO.NET ADO.NET是一组用于和数据源进行交互的面向对象类库.通常数据源是数据库,但也可以是文本文件.Excel表格.XML文件. 说白了就是使用.net操作数据库的一套类库. ADO.NE ...

  9. C#对SQL数据库操作类简介:Connection、Command、DataReader、DataSet、DataAdapter

    在说C#操作数据库之前需要先说下ADO.NET.ADO.NET的名称起源于ADO(ActiveX Data Objects),是一个COM组件库,用于在以往的Microsoft技术中访问数据.之所以使 ...

随机推荐

  1. NULL指针区域(NULL定义为0-65535之间的任何数都可以)

    NULL指针区域0x00000000-0x0000FFFF:65535字节 这个区域的作用是用来帮助程序员发现内存分配失败后未检查就使用的错误.比如使用malloc分配内存失败,返回NULL,而又未做 ...

  2. WP8.1的shell:SystemTray去哪了?

    WP8.1 中的SystemTray被 StatusBar 代替了.在Windows.UI.ViewManagement 命名空间下,而且只能在后台代码中设置,XAML中不行.用法是这样的: Stat ...

  3. 浅析在QtWidget中自定义Model(beginInsertRows()和endInsertRows()是空架子,类似于一种信号,用来通知底层)

    Qt 4推出了一组新的item view类,它们使用model/view结构来管理数据与表示层的关系.这种结构带来的功能上的分离给了开发人员更大的弹性来定制数据项的表示,它也提供一个标准的model接 ...

  4. UWP中的消息提示框(二)

    在UWP中的消息提示框(一)中介绍了一些常见的需要用户主动去干涉的一些消息提示框,接下来打算聊聊不需要用户主动去干涉的一些消息提示框.效果就是像双击退出的那种提示框. 先说说比较简单的吧,通过系统To ...

  5. ASP.NET获取客户端、服务器端基础信息

    1. 在ASP.NET中专用属性: 获取服务器电脑名:Page.Server.ManchineName 获取用户信息:Page.User 获取客户端电脑名:Page.Request.UserHostN ...

  6. 深入理解 Win32 PE 文件格式 Matt Pietrek(慢慢体会)

    这篇文章假定你熟悉C++和Win32. 概述 理解可移植可执行文件格式(PE)可以更好地了解操作系统.如果你知道DLL和EXE中都有些什么东西,那么你就是一个知识渊博的程序员.这一系列文章的第一部分, ...

  7. Delphi 与 VC 共享接口和对象

    我经常会用 Delphi 写一些工具和应用,为了扩展方便,大部分都会做成插件形式. 迫于某些原因,我的插件不得不用其他开发工具来完成,比如 VC. 于是有个大问题需要解决:如何让 D 和 VC 互相通 ...

  8. c#实现类似数据的行锁

    当我们有一些这样的需求,比如某个订单中下单,修改等等这些是单例执行的,不能同步操作,当然这样的情况你可以使用数据库的行锁来实现,但是我们代码里面实现的话 ,我们也要用到锁,大部分情况下我们使用lock ...

  9. Struts2 学习笔记(概述)

    Struts2 学习笔记 2015年3月7日11:02:55 MVC思想 Strust2的MVC对应关系如下: 在MVC三个模块当中,struts2对应关系如下: Model: 负责封装应用的状态,并 ...

  10. spring cloud之eureka简介

    最近线上的接口出了一些问题,有一些可能不是代码的问题,但是由于是测试和其他方面的同事爆出来的,所以感觉对接口的监控应该提上日程. 经过搜索发现,spring cloud的eureka就是专门做这方面工 ...