1.使用Connection连接数据库的步骤:

  (1).添加命名空间 System.Data.SqlClient(注意:初学者经常会忘记)

  (2)定义连接字符串。连接SQL Server 数据库时:

  server=服务器名;database=数据库名;uid=用户名;pwd=密码;例如:要连接本机上的StudentManagement数据库,用户名为sa,密码为111

  string connString="server=.;database=StudentManagement;uid=sa;pwd=111;"

  (3).创建Connection对象:

  SqlConnection connStr=new SqlConnection(connSting);

  (4).打开数据库:

  conn.Open();

  (5).对数据库操作完毕后关闭数据库连接

  conn.Close();

  2.Command对象:

  (1).command对象可以用来对数据库发出具体的操作指令,例如对数据库的查询、增加、修改、删除

  (2).创建Command对象,并设置它的属性:

  SqlCommand command =new SqlCommand();

  command.Connection=connection;

  command.CommandText=sqlQuery(sqlQuery为查询语句);

  (3).Command对象的主要方法:

  ExecuteNonQuery:执行后不返回任何行,对于update、insert、delete语句,返回影响的行数对于其他类型的语句,返回值为-1

  ExecuteReader:执行查询语句,返回DataReader对象

  ExecuteScalar:执行查询,并返回查询结果的第一行第一列,忽略其他列或行

  ExecuteXmlreader:将CommandText发送到Connection并生成一个XmlReader

  3.DataReader对象:

  (1).DataReader对象可以从数据库中一只读、只进的方式查询数据,每次的操作只有一个记录保存在内存中

  (2).DataReader对象的主要方法:

  Read:读取下一条数据

  Close:关闭DataReader对象

  (3).使用DataReader提取数据的步骤:

  (a).建立与数据库的连接并打开

  (b).创建一个Command对象

  (c).从Command对象中创建DataReader对象

  (d).使用DataReader读取并显示

  可以使用一个循环利用Read方法便利数据库中行的信息,如果要获取该行中某列的值,只需要使用"["和"]"运算符就可以了

  (e).分别关闭DataReader对象和数据库的连接

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data.SqlClient; namespace ado.netDemo
{
class Program
{
static void Main(string[] args)
{
//定义连接字符串
string connStr = @"server=SUNNY\SQLEXPRESS;database=TestDB;UID=sa;PWD=123456";
//连接数据库
SqlConnection conn = new SqlConnection(connStr);
//SQL语句
string sql = "select * from tb_Students";
//string sql = "insert into tb_Students(SID, Name, Password, Sex, Age, Address, Phone, QQ) Values('20117750120','小鸟电动车','123','男',21,'HONGKONG','18736000000','1147016165')";
//string sql = "update tb_Students set SID='20117750119' where SID='20117750120'";
//string sql = "delete from tb_Students where SID='20117750101'";
//执行SQL语句
SqlCommand cmd = new SqlCommand(sql,conn); conn.Open(); SqlDataReader reader = cmd.ExecuteReader();
while (reader.Read())//read()一直读取下一个数据
{ Console.WriteLine(string.Format("{0}\t{1}\t{2}\t{3}", reader[],reader[], reader[], reader[]));
}
reader.Close();
//查询数据
#region
//ExecuteScalar执行sql查询语句的第一行第一列,忽略其他行其他列。
//object result = cmd.ExecuteScalar();
//Console.WriteLine("共查询到有:{0}行数据", result.ToString()); #endregion
//增加数据
#region
//int result = cmd.ExecuteNonQuery();
//if (result < 1)
//{
// Console.WriteLine("数据插入失败,请检查填写信息,重新操作");
//}
//else
//{
// Console.WriteLine("数据插入成功!");
//}
#endregion
//修改数据
#region
//int result = cmd.ExecuteNonQuery();
//if (result < 1)
//{
// Console.WriteLine("数据修改失败,请检查填写信息,重新操作");
//}
//else
//{
// Console.WriteLine("数据修改成功!");
//}
#endregion
//删除数据
#region
//int result = cmd.ExecuteNonQuery();
//if (result < 1)
//{
// Console.WriteLine("数据删除失败,请检查填写信息,重新操作");
// Console.WriteLine("{0}行收到影响", result);
//}
//else
//{
// Console.WriteLine("数据删除成功!");
// Console.WriteLine("{0}行收到影响", result);
//}
#endregion conn.Close();
Console.ReadKey(); }
}
}

(二)ADO.NET数据库访问技术:

  通过这几天的学习,下面来把有关数据适配器和数据集方面的知识点总结一下:

  一.DataSet 和DataTable:

  数据集在ADO.net中的对象是DataSet,DataSet由一个或多个DataTable组成

  1.DataTable:

  (1).DataTable是表格数据块在内存中的表示,DataTable对象由DataColumns集合以及DataRows集合组成。对数据库检索后,被取回的数据就存放在DataTable对象中

  (2).DataTable对象的主要的属性:

  CaseSensitive:表中的字符串是否区分大小写

  Columns:返回属于这个表的列集合

  DataSet:获得这个表的行集合

  TableName:获得或设置表的名称

  HasChanges:判断数据集是否更改了

  (3).dataTable对象的主要方法:

  Clear:清除DataTable内所有的行数

  NewRow:增加一行

  2、DataSet:数据装置

  (1).DataSet的主要属性:

  Table:可以访问DataSet中表的集合

  (2).DataSet对象的主要方法

  Clear:完全清除DataSet的数据

  Clone:创建与原DataSet具有相同结构和相同行的DataSet

  Copy:创建具有相同结构的新DataSet,但不包含任何行

  (3).填充DataSet数据集:使用数据适配器DataAdapter,DataAdapter对象的Fill()方法可以给DataSet填充数据,例如

  (Fill(参数1,参数2 )第一个参数指定要填充的DataSet,第二个参数是dataSet中要加载数据的Datatable名称)

  (4).使用dataAdapter对象填充DataSet数据库的步骤:

  (a).建立数据库的连接,并打开盖连接

  string connString="、、、";

  SqlConnection mySqlConnection=new SqlConnection(connString);

  mySqlConnection.Open();

  (b).定义要执行的SQl语句

  string sqlQuery="、、、、";

  (c).创建数据集DataSet对象

  DataSet ds=new DataSet();

  (d) .创建数据适配器DataAdapter

  sqlDataAdapter da=new sqlDataAdapter(sqlQuery,mySqlConnection);

  (e).使用DataAdapter对象的Fill()方法填充数据集

  a.Fill(ds,"Table");//DataSet可以被看作是一个虚拟的表或表的集合,这里被填充的表的名称在Fill方法中命名为Table

  (f).关闭数据库连接

  mySqlConnection.Close();

  注意:close与Dispose的区别:Close关闭以后还能打开;Dispose是直接销毁,不能再次使用

 using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data.SqlClient;
using System.Configuration;
using System.Data; namespace ado.netDemo1
{
public partial class Test1 : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
//string connStr = ConfigurationManager.ConnectionStrings["connStr"].ToString();
//SqlConnection conn = new SqlConnection(connStr);
//conn.Open();
//string sql = "select * from tb_Students";
//SqlDataAdapter adapter = new SqlDataAdapter(sql, conn);
//DataSet dataset = new DataSet();
//adapter.Fill(dataset);
//conn.Close();
//GridView1.DataSource = dataset.Tables[0].ToString();
//GridView1.DataBind(); GridView1.DataSource = getResult();
this.GridView1.DataBind();
} //将数据库信息田中到DataSet的DataTable中
public DataSet getResult()
{
string connStr = ConfigurationManager.ConnectionStrings["connStr"].ToString();
SqlConnection conn = new SqlConnection(connStr);
conn.Open();
string sql = "select * from tb_Students";
//创建数据适配器
SqlDataAdapter adapter = new SqlDataAdapter(sql, conn);
//创建数据集对象
DataSet dataset = new DataSet();
//使用适配器对象Fill()方法填充DataSet数据集
adapter.Fill(dataset);
conn.Close();
return dataset;
}
}
}

  (3)访问DataSet数据集:

  (1).访问DataTable:当访问的数据被存放到数据集中后,可以用两种方式访问DataTable:按表名访问和按索引(索引从0开始)访问

  (2).访问行和列

  总结:希望通过小编写的 ADO.NET数据库访问技术的两种方法可以帮助各位网友们在做网站开发的时候,数据库连接时可以得到更好的解答。

【ADO.NET基础知识】SqlConnection、command、DataSet 、DataTable、dataAdapter的更多相关文章

  1. ADO.NET基础知识学习(SQLCOnnection&SQLCommand&SQLDataReader&SQLDataAdapter&DataSet)

    通过ADO.NET技术,我们可以高效的完成客户端同数据库之间的数据访问操作,便于我们在客户端程序简便高效的访问以及获取数据库中的有用数据,同时也可以对数据库中的数据进行更新,即可以完成客户端与数据库之 ...

  2. ADO.NET基础知识

    ADO.NET定义 ADO是ActiveX Data Objects的缩写,ADO.NET是数据库应用程序和数据源之间沟通的桥梁,主要提供一个面向对象的数据访问架构,用来开发数据库应用程序,就是一组类 ...

  3. ado.net中的 sqlconnection sqlcommand datareader dataset SqlDataAdapter之间的关系

    Connection: 和数据库交互,必须连接它.连接帮助指明数据库服务器.数据库名字.用户名.密码,和连接数据库所需要的其它参数.Connection对象会被Command对象使用,这样就能够知道是 ...

  4. ADO.NET基础巩固-----连接类和非连接类

          最近的一段时间自己的状态还是不错的,早上,跑步,上自习看书,下午宿舍里面编程实战,晚上要么练习代码,要么去打球(在不打就没机会了),生活还是挺丰富的. 关于C#的基础回顾就先到前面哪里,这 ...

  5. .Net Core 系列:2、ADO.Net 基础

    目录: 1.环境搭建 2.ADO.Net 基础 3.ASP.Net Core 基础 4.MD5.Sha256.AES 加密 5.实现登录注册功能 6.实现目录管理功能 7.实现文章发布.编辑.阅览和删 ...

  6. ADO.NET基础开发

    ADO.NET是微软新一代.NET数据库的访问架构,ADO是ActiveX Data Objects的缩写.ADO.NET是数据库应用程序和数据源之间沟通的桥梁,主要提供了一个面向对象的数据访问架构, ...

  7. ADO.NET基础03

    数据库和VS的连接,实现数据的同步,让用户的一切信息都可以在数据库中留下记录. ADO.NET基础      它是连接所有数据库的一种特殊的技术,提供对不同的数据库统一操作接口. 在VS中也可以添加数 ...

  8. ADO.NET基础01(ADO.NET组成,数据库的方式,SqlCommand,SqlDataReader)

    什么是ADO.NET: ADO.NET就是一组类库,这组类库可以让我们通过程序的方式访问数据库,就像System.IO下的类操作文件一样, System.Data.这组类是用来操作数据库(不光是MSS ...

  9. 如鹏网学习笔记(六)ADO.Net基础

    ADO.Net基础 一.ADO.Net简介 1,程序要通过SQL语句自动化的操作数据库,必须要用一个类库, 类库要提供execute("insert into ...")/exec ...

随机推荐

  1. Python--高阶函数、函数嵌套、名称空间及变量作用域、闭包、装饰器

    1.高阶函数(map/reduce/filter) 高阶函数是指函数的参数可以是函数 这篇总结几个常用的高阶函数:map/reduce/filter map函数.reduce函数.filter函数都是 ...

  2. WPF 浏览PDF 文件

    添加成功后会在工具箱里看到下图所示的控件.打开VS2010,新建项目(WpfPDFReader),右键项目添加User Control(用户控件).因为Adobe PDF Reader COM 组件是 ...

  3. 【JVM从小白学成大佬】6.创建对象及对象的访问定位

    <JVM从小白学成大佬>系列推出到现在,收到了很多小伙伴的好评,也收到了一些小伙伴的建议,在此表示感谢. 有几个小伙伴提出了希望出一篇介绍对象的创建及访问,猿人谷向来是没有原则的,小伙们要 ...

  4. POJ - 2516 Minimum Cost 每次要跑K次费用流

    传送门:poj.org/problem?id=2516 题意: 有m个仓库,n个买家,k个商品,每个仓库运送不同商品到不同买家的路费是不同的.问为了满足不同买家的订单的最小的花费. 思路: 设立一个源 ...

  5. codeforces 1041 E. Tree Reconstruction 和度数有关的构造树

    CF 1041E:http://codeforces.com/contest/1041/problem/E 题意: 告诉你一个树的节点个数,显然有n-1条边.已知去掉一条边后,两个集合中最大的节点值. ...

  6. 高可用的K8S集群部署方案

    涉及到的内容 LVS HAProxy Harbor etcd Kubernetes (Master Worker) 整体拓补图 以上是最小生产可用的整体拓补图(相关节点根据需要进行增加,但不能减少) ...

  7. python中列表,数字,字符串函数总结

    列表list: arr = [] 1.可以定义空列表 2.可以定义只有一个元素的列表 3.元素可以是任意类型 arr.append('abc')末尾添加 arr.insert(index,objec) ...

  8. debug 模式缓慢

    debug 模式启动服务器,然后在 breakopints下可以看到打的断点.清除全部重启服务器,问题解决.

  9. FreeSql (二十八)事务

    FreeSql实现了四种数据库事务的使用方法,脏读等事务相关方法暂时未提供.主要原因系这些方法各大数据库.甚至引擎的事务级别五花八门较难统一. 事务用于处理数据的一致性,处于同一个事务中的操作是一个U ...

  10. pycharm中报ImportError: libcublas.so.9.0错误的解决方法。

    前些天不知为啥cuda不能用了,nvidia-smi也没反应.然后我就重新装了一下cuda.后来使用pycharm远程连接时,居然报错了. ImportError: libcublas.so.9.0: ...