1. ODBC、OLEDB、ADO、ADO.NET之间的关系

ODBC: 开放数据库互连(ODBC)是MICROSOFT提出的数据库访问接口标准。ODBC(Open DatabaseConnectivity,开放数据库互连)提供了一种标准的API(应用程序编程接口)方法来访问数据库管理系统(DBMS)。

OLEDB: OLEDB(ObjectLinking and Embedding,Database,又称为OLE DB或OLE-DB),一个基于COM的数据存储对象,能提供对所有类型的数据的操作。

ADO: ADO (ActiveXDataObjects)是一个用于访问数据源的COM组件。它提供了编程语言和统一数据访问方式OLE DB的一个中间层。允许开发人员编写访问数据的代码而不用关心数据库是如何实现的,而只用关心到数据库的连接。

ADO.NET: ADO虽然是比较成功的产品,但ADO本身的架构仍然有缺陷,尤其是在开发网络应用程序时,Recordset无法脱机,严重影响了网络应用的开发。ADO.NET引入了脱机型数据模型的概念,成功解决了ADO所不能及的问题。

关系:ODBC位于数据访问的最底层,OLEDB次之,ADO位于最上层。我们的应用程序可以通过三种方式访问数据库,分别是应用程序——ODBC——数据库,应用程序——OLEDB——ODBC——数据库,应用程序——ADO——OLEDB——ODBC——数据库。

2.ADO.NET类集合主要由五大核心组件类组成:Connection(数据库连接)、Command(数据库的命令)、DataReader(数据库的读取器)、DataSet(数据集)和 DataAdaper(数据库的适配器)。

3. 数据库连接

使用SqlConnection对象连接SQL Server:ConnectionString = "server=localhost;database=TestData;;User Id=danfoss;Password=danfoss;" (如果使用SQL EXPRESS, 改为server=localhost/sqlexpress)

                using (SqlConnection conn = new SqlConnection(ConnectionString))
{
conn.Open(); operate database here...... conn.Close();
}

使用OleDbConneetion连接支持OLE DB的数据库,如Access: ConnectionString = "Provider = Microsoft.Jet.OLEDB.4.0;Data Sourse = Access数据库;UserId = 用户名;Password = 密码;"

确保资源释放:1. 访问结束时,调用close()方法; 2.利用using 语句

配置连接字符串,并使用ConfigurationManager访问:

<configuration>
<connectionStrings>
<add name="conn1" connectionString="server=192.168.0.23;database=TestData;;User Id=danfoss;Password=danfoss;"/>
</connectionStrings>
</configuration>
using System.Configuration;

String connsql = ConfigurationManager.ConnectionStrings["conn1"].ToString();

4. 数据库执行命令

<Provider>Command类提供了以下可执行的命令:

  • ExcuteNonQuery() ----- 执行命令,返回受影响的记录个数,可用于update, delete, insert into 语句;
  • ExcuteReader() ------ 返回 IDataReader 读取器;
  • ExcuteScalar()   ------ 返回结果集中的第一行第一列的值;
  • ExcuteXMLReader() ------ 仅用于SqlCommand,返回一个XmlReader对象,可以遍历从数据库中返回XML片段;

以ExcuteReader()读取Sql Server为例,其他类似:

            String connsql = @"server=192.168.0.23;database=TestData;;User Id=danfoss;Password=danfoss;";
try
{
using (SqlConnection conn = new SqlConnection(connsql))
{
conn.Open();
string sqlStr = "select * from StudentInfo";
SqlCommand comm = conn.CreateCommand();
comm.CommandText = sqlStr;
comm.CommandType = System.Data.CommandType.Text;
SqlDataReader sr = comm.ExecuteReader();
while (sr.Read())
{
Console.WriteLine("ID:{0},Name:{1},Phone:{2},Time:{3}", sr.GetInt64(), sr.GetString(), sr[], sr[]);
}
sr.Close();
conn.Close();
}
}
catch (Exception err)
{
Console.WriteLine(err.Message);
}
finally
{ }

  IDataReader是一个只能向前的读取器,即只能沿着一个方向遍历数据,数据库连接会一直处于打开状态,直到显式关闭。若在ExecuteReader()中传入参数CommandBehavior.CloseConnection,就可以在关闭读取器时强制关闭数据库连接。

  SqlDataReader 有个索引器,可以根据字符串(即数据库表中的字段名),数字来获取数据,其中直接以数字索引访问速度更快。但以索引器访问返回的是Object ,需要类型转换,因此还有一种更快的访问方式,以Get开头的一组类型安全的方法,例如GetInt32(), GetFloat(), GetString()。

ADO.NET 基础学习笔记1的更多相关文章

  1. 【C#编程基础学习笔记】4---Convert类型转换

    2013/7/24 技术qq交流群:JavaDream:251572072  教程下载,在线交流:创梦IT社区:www.credream.com [C#编程基础学习笔记]4---Convert类型转换 ...

  2. 【C#编程基础学习笔记】6---变量的命名

    2013/7/24 技术qq交流群:JavaDream:251572072  教程下载,在线交流:创梦IT社区:www.credream.com [C#编程基础学习笔记]6---变量的命名 ----- ...

  3. 1.C#基础学习笔记3---C#字符串(转义符和内存存储无关)

    技术qq交流群:JavaDream:251572072  教程下载,在线交流:创梦IT社区:www.credream.com ------------------------------------- ...

  4. Java基础学习笔记总结

    Java基础学习笔记一 Java介绍 Java基础学习笔记二 Java基础语法之变量.数据类型 Java基础学习笔记三 Java基础语法之流程控制语句.循环 Java基础学习笔记四 Java基础语法之 ...

  5. Mysql数据库基础学习笔记

    Mysql数据库基础学习笔记 1.mysql查看当前登录的账户名以及数据库 一.单表查询 1.创建数据库yuzly,创建表fruits 创建表 ) ) ,) NOT NULL,PRIMARY KEY( ...

  6. 0003.5-20180422-自动化第四章-python基础学习笔记--脚本

    0003.5-20180422-自动化第四章-python基础学习笔记--脚本 1-shopping """ v = [ {"name": " ...

  7. Java基础学习笔记(一)

    Java基础学习笔记(一) Hello World 基础代码学习 代码编写基础结构 class :类,一个类即一个java代码,形成一个class文件,写于每个代码的前端(注意无大写字母) XxxYy ...

  8. C#RabbitMQ基础学习笔记

    RabbitMQ基础学习笔记(C#代码示例) 一.定义: MQ是MessageQueue,消息队列的简称(是流行的开源消息队列系统,利用erlang语言开发).MQ是一种应用程序对应用程序的通信方法. ...

  9. handlebars.js基础学习笔记

    最近在帮学校做个课程网站,就有人推荐用jquery+ajax+handlebars做网站前端,刚接触发现挺高大上的,于是就把一些基础学习笔记记录下来啦. 1.引用文件: jquery.js文件下载:h ...

随机推荐

  1. Netflix性能监控工具Vector

    简介: Vector是Netflix开源的主机级性能监控框架,向每位工程师的浏览器提供精心挑选的高分辨率系统和应用程序指标. 登录到系统并从shell运行大量命令是一种选择,但是通常涉及的复杂性可能成 ...

  2. Scala学习笔记:重要语法特性

    1.变量声明 Scala 有两种变量, val 和 var  val的值声明后不可变,var可变 val msg: String = "Hello yet again, world!&quo ...

  3. Linux时间子系统之一:认识timer_list和timer_stats和使用

    内核版本:v3.4.xxx 一.前言 内核提供了方便查看当前系统TickDevice.活动的Timer列表以及Timer使用的统计信息. 内核分别用两个节点来表示TimerList和Timer统计信息 ...

  4. Jmeter4.0分布式测试时启动Jmeter.server时报错

       最近又开始研究Jmeter,将新版本4.0下载下来体验,准备远程分布式测试,又出现一些问题,废话不多说,直入主题把! Windows 系统启动Jmeter 4.0的JmeterServer.ba ...

  5. 居中 html css

    <div id="main" style="width:800px;height: 600px;margin:0 auto"> <!-- 这里 ...

  6. setInterval setTimeout 详解

    JavaScript的setTimeout与setInterval是两个很容易欺骗别人感情的方法,因为我们开始常常以为调用了就会按既定的方式执行, 我想不少人都深有同感, 例如 setTimeout( ...

  7. 使用STM32Cube在STM32F7开发板上实现SD+Freertos+Fatfs

    简介 最近项目中可能需要使用到SD卡,所以需要对SD卡的配置和使用调研,在配置过程中遇到了一些问题,在此记录一下. STM32Cube配置 Pinout 只需要注意绿色部分的设定 Clock配置 这里 ...

  8. 【bzoj 4176】 Lucas的数论 莫比乌斯反演(杜教筛)

    Description 去年的Lucas非常喜欢数论题,但是一年以后的Lucas却不那么喜欢了. 在整理以前的试题时,发现了这样一道题目“求Sigma(f(i)),其中1<=i<=N”,其 ...

  9. bzoj 1901 主席树+树状数组

    修改+查询第k小值 单纯主席树修改会打乱所有,所以再套一个树状数组维护前缀和使得修改,查询都是log 对了,bzoj上不需要读入组数,蜜汁re.. #include<cstdio> #in ...

  10. noip 2015 斗地主 大爆搜!!!

    反正肯定是大模拟 但是每一个可以出的牌都搜一定不是最优的 考虑最特殊的出牌方案:顺子(单,对,三) 每一种方案再加上暴力贪心打出剩下的牌的步数 #include<cstdio> #incl ...