ADO.NET整理 [转]
虽然我们都知道ADO.NET是对数据库的操作,但是要真的说出ADO.NET的具体含义还不是很容易。
ADO.NET是ActiveX Data Objects的缩写,它是一个COM组件库,用于在microsoft技术中访问数据。之所以叫ADO.NET,应该是微软自己打的广告,希望在NET编程环境中优先使用这种数据访问接口。上面这段话基本来自百度百科。简单来说,ADO.NET就是一种数据访问接口,可以让我们在程序中调用相应的类库对数据库(通常为SQL Server,也可以是access 等其他数据库)进行增删改查等操作。
ADO.NET的几大组成部分
ADO.NET由五大类库组成,分别是:
- Connection(用于建立与 数据库的连接)
- Command(用于执行SQL语句)
- DataReader(用于读取数据)
- DataAdapter(用于填充把数据填充到DataSet)
- DataSet(数据集,用于程序中)
通常,从程序中访问数据库的方法是:
- 创建一个到数据库的连接
- 打开数据库连接
- 创建ADO记录集
- 从记录集中提取需要的数据
- 关闭记录集
- 关闭连接
下面就分别根据这一个过程结合ADO.NET的五大类库进行解释。
要想使用ADO.NET需要在程序中引用System.Data.SqlClient。其中包含了对Sql Server进行操作的数据访问类:
- SqlConnection:连接数据库
- SqlCommand:数据库命名对象
- SqlCommandBuilder:生成SQL命令
- SqlDataReader:数据读取器
- SqlDataAdapter:数据适配器,用于填充DataSet
- SqlParameter:为存储过程定义参数
- SqlTransaction:数据库事务
建立连接
首先,要想访问数据库,我们需要一个媒介把程序与数据库连接起来。这就是连接字符串,它的基本语法为:Data Source(数据源) + Initial Catalog(数据库名称) + User ID(用户名) + Password(密码)。
String connectString = "Data Source = myServerAddress;Initial Catalog = myDataBase;User Id = myUserName; Password = myPassword;";
或者
String connectString = "Server =myServerAddress;Database = myDataBase; User Id = myUsername; Password = myPassword;";
注意:对于Sql Server来说,它支持两种身份验证方法,一种是windows身份验证,另一种是Sql Server身份验证。如果要用windows身份验证,就需要在连接字符串中包括Integrated Security属性。该属性默认为False。需要设置为True后才能使用windows身份验证。
除了这几个必须的字段,连接字符串中还有许多可选的属性,在这里我就不一一列举,列出一些相关资料供感兴趣的朋友自行查阅,一个连接字符串可以包含哪些属性(http://book.51cto.com/art/200812/99995.htm)。
接着,有了连接字符串就可以创建连接对象了。
SqlConnection connection = new SqlConnection(connecString);
或者可以使用专门的连接字符串生成器:
SqlConnectionStringBuilder connectionStringBuilder = new SqlConnectionStringBuilder()
{
DataSource=”“,
InitialCatalog=”“,
UserID=”“,
Password=””
};
SqlConnection connection = new SqlConnection(connectionStringBuilder.ToString());
然后使用连接对象可以打开或关闭连接。
connection.Open();
connection.Close();
执行命令
打开连接之后就可以操作数据库了,在这里需要用到SqlCommand命令对象。
它具有四个主要属性,这些属性会在初始化的时候赋默认值:
CommandText:空字符串(”“)
CommandTimeout:30
CommandType:CommandType.Text
Connection:Null
创建命令对象:
SqlCommand command = connection.CreateCommand();
或
SqlCommand command = new SqlCommand();
SqlCommand包含了几个重要的属性:
CommandText:用于获取或设置药对数据源之行的SQL语句、表明或存储过程。
CommandType:设置你执行的SQL语句类型,有三个枚举,分别是Text(SQL文本命令),StoredProcedure(存储过程),TableDirect(表名)。
Parameters:设置你的T-SQL中需要用到的参数。
几个重要的方法:
ExecuteNonQuery:返回被SQL语句执行影响的行数(int),主要执行增删改操作。
ExecuteReader:执行SQL或存储过程,返回的是SqlDataReader类型,主要用来查询。
ExecuteScalar:返回执行结果集中的第一行第一列,如果没有数据,则返回NULL。
CreateParameter:创建SqlParameter实例。
举例说明:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;//必须
using System.Data.SqlClient;//必须
namespace Command
{
class Program
{
static void Main(string[] args)
{
SqlConnectionStringBuilder conStr = new SqlConnectionStringBuilder();
conSt.DataSource=@".\SQLEXPRESS";
conStr.IntegratedSecurity=true;
conStr.InitialCatalog="db_Test";
StringBuilder strSQL = new StringBuilder();
for(int i=0;i<=100;i++)
{
strSQL.Append("insert into tb_Test");
strSQL.Append("values('");
string name = "test"+i.ToString();
strSQL.Append(name);
}
using(SqlConnection con = new SqlConnection(conStr.ConnectionString))
{
con.Open();
SqlCommand cmd = new SqlCommand(strSQL.ToString(),con);
int impactedNumber = cmd.ExecuteNonQuery();//返回受影响的行数
object firstData = cmd.ExecuteScalar();//返回执行结果中的第一行第一列,此方法可用于获取插入数据的ID,(int lineNumber =(int)cmd.ExecuteScalar();)
}
}
}
}
SQL参数
若想在程序中传递参数给数据库,可以使用SqlParameter。该类有几个重要的属性:
- ParameterName:设置参数名
- Value:给参数设置值
- Size:设置参数字节最大长度
SqlDbType:参数在SQL中的类别
和几个重要的方法:
AddWithVlue
- Add
AddRange
举例说明:
SqlConnection connection =new SqlConnection(""))
{
SqlCommand cmd = connection.CreateCommand();
cmd.CommandText="";
cmd.Parameters.Add("@name",SqlDbType.NVarChar).Value = "deng";//方法一
cmd.Parameters.AddWithValue(@"name","deng");//方法二
SqlParameter[] parameters = new SqlParameter[]
{
new SqlParameter("@name",SqlDbType.NvarChar,100){Value="deng"},
};
cmd.Parameters.AddRange(parameters);//可以放一个参数数组,包含多条参数,在此只举一个例子
}
可以通过cmd.Parameters[i].Value设置和读取数值。
数据读取
利用查询语句得到的数据信息需要通过数据读取器进行操作。
举例:
SqlConnetion con = new SqlConnection("")
{
con.Open();
SqlCommand cmd = con.CreateCommand();
cmd.CommandText="";
SqlDataReader dr = cmd.ExecuteReader(CommandBehavior.CloseConnection)
{
While(dr.Read())
{
string str = dr.GetSqlString(0).ToString();
}
}
}
介绍几个常用的方法:
- GetOrdinal:可以获取指定列名的序列号,int name = dr.GetOrdinal(“name”);
- GetName:与上面的方法对应,可以通过列号返回列名字。
- IsDBNull:判断当前读取的数据是否为Null。
- NextResult:当查询为批处理查询时,使用这个方法去获取下一个结果集,返回值为Bool,如果存在多个结果集,则为true;否则为false。
- Read:读取数据。
常用属性有:
- HasRow:判断是否有数据。
- FieldCount:获取读取的列数。
- IsClosed:判断读取的数据流是否关闭。
SqlDataReader是连接相关的,也就是说与数据库的连接一断开就无法读取数据库中的数据,说明查询结果并不是放在程序中,而是放在数据库的服务中。
事务
需要用到SqlTransaction类,需要在指定位置命名存储点,该存储点之后的操作都将会回滚。
例子:
SqlConnection con = new SqlConnection(strCon);
con.Open();
SqlTransaction transaction = con.BeginTransaction();
SqlCommand cmd = con.CreateCommand();
cmd.CommandText = ""
cmd.Transaction = transaction;
transaction.Save("transaction point");
transaction.Rollback("transaction point");
数据适配器
SqlDataAdapter类有四个重载构造函数:
- 无参
- SqlDataAdapter(SqlCommand)
- SqlDataAdapter(String,SqlConnection)
- SqlDataAdapter(String, ConnectionString)
填充数据例子:
DataSet dataSet = new DataSet();
SqlConnection con = new SqlConnection("");
con.Open();
SqlCommand cmd = con.CreateCommand();
cmd.CommandText="select xxx from tb_xxx";
SqlDataAdapter dataAdapter = new SqlDataAdapter(cmd);
dataAdapter.Fill(dataSet);
填充后的数据可以使用SqlCommandBuilder进行增删改查。
例子:
SqlConnection con = new SqlConnection(ConnectionString();
con.Open();
SqlDataAdapter da = new SqlDataAdapter("select xxx from tb_xx");
DataSet ds =new DataSet();
da.Fill(ds);
SqlCommandBuilder cmdBuilder = new SqlCommandBuilder(da);
DataRow row = ds.Tables[0].NewRow();
row[0]="a";
row[1]="b";
ds.Tables[0].Rows.Add(row);
da.Update(ds);
SqlCommandBuilder 可以把DataSet增加的数据转化为SQL语句用来更新数据库。然后调用Update方法。
文章来源:https://www.cnblogs.com/dfhelloworld/p/4951845.html
ADO.NET整理 [转]的更多相关文章
- ADO.NET--收藏整理别人的教程
本文所有内容均从前辈的博客中收集整理而来,仅供自己学习参考的时候快速访问用. ADO.NET入门教程(一) 初识ADO.NET ADO.NET入门教程(二)了解.NET数据提供程序 ADO.NET入门 ...
- 关于ADO.NET的一些知识整理
ADO.NET是什么 虽然我们都知道ADO.NET是对数据库的操作,但是要真的说出ADO.NET的具体含义还不是很容易. ADO.NET是ActiveX Data Objects的缩写,它是一个COM ...
- ado.net知识整理
对ado.net总是半知半解,五大对象也总是混淆,近期自己做小项目练手,整理了一些知识点 ado.net的无要素(摘自其他博文) Connection 物件 Connection 对象主要是开启 ...
- 从头开始学习数据库及ADO.NET——竹子整理
目前为止,学习编程一年有余,写过管理系统,写过商城,写过桌面,接触的多了,乱七八糟的点太多,一堆前段框架,后台类库,纷纷杂杂,更新迭代之快也是令人咋舌.于是我就在想,作为一名程序员,哪些内容是实打实的 ...
- ADO.NET的整理
ADO.NET的几个对象 Connection:管理数据库的连接 Command:对数据库执行命令 DataReader:数据流读取器,返回的数据都是快速的且只是“向前”的数据流.无法实例化,只能通过 ...
- 【资料整理】ADO.NET
ADO.NET: 1.SYSTEM.DATA 命名空间下类的集合的统称,用于操作 连接数据库的 它提供了统一的编程接口,可以操作不同的数据库 数据库实例:默认实例(MSSQLSEVER)和命名实例(M ...
- ADO.NET数据访问模板整理
/// <summary> /// 数据访问类:hi_test /// </summary> public partial class TestDA { public Test ...
- ADO.Net笔记整理(一)
几次装机,Notes已烟消云散,近日因为Node.js死活搞不定,无奈装机,备份好的东东,没想到磁盘扇区出现异常,可能是PE启动盘的病毒,只好将磁盘全部重新分区,恢复数据也懒得恢复了,日积月累关乎将来 ...
- 从头开始学习数据库及ADO.NET之PostgreSql字段约束——竹子整理
约束数据表列执行的规则.这些是用来防止无效的数据被输入到数据库中..这确保数据库中的数据的准确性和可靠性. 约束可以是列级或表级.仅适用于表级约束被应用到整个表的列级约束.为列定义的数据类型,本身是一 ...
随机推荐
- [算法] 数据结构 splay(伸展树)解析
前言 splay学了已经很久了,只不过一直没有总结,鸽了好久来写一篇总结. 先介绍 splay:亦称伸展树,为二叉搜索树的一种,部分操作能在 \(O( \log n)\) 内完成,如插入.查找.删除. ...
- 几年前,为什么我撸了一套RabbitMQ客户端?
之前文章说过,如果使用 RabbitMQ,尽可能使用框架,而不要去使用 RabbitMQ 提供的 Java 版客户端. 细说起来,其实还是因为 RabbitMQ 客户端的使用有很多的注意事项,稍微不注 ...
- RADAR毫米波雷达传感器
RADAR毫米波雷达传感器 TI 利用先进的集成式射频 CMOS 雷达技术提供品类齐全的 60GHz 和 77GHz 传感器产品系列 通过高性能集成射频互补金属氧化物半导体 (CMOS) 雷达技术,可 ...
- GPU自动调度卷积层
GPU自动调度卷积层 本文对GPU使用自动调度程序. 与依靠手动模板定义搜索空间的基于模板的autotvm不同,自动调度程序不需要任何模板.用户只需要编写计算声明,无需任何调度命令或模板.自动调度程序 ...
- Darknet_Yolov3模型搭建
Darknet_Yolov3模型搭建 YOLO(You only look once)是目前流行的目标检测模型之一,目前最新已经发展到V3版本了,在业界的应用也很广泛.YOLO的特点就是"快 ...
- Minecraft类游戏地形生成机制
目录 前言 生成地形高度 生成生物群落 模拟雨水侵蚀.生成河流(未完) 生成洞穴.裂谷 生成植被 放置树木(Bezier曲线) 生成建筑 生成发展域(元胞自动机模型) 放置建筑(DFS) 连接道路(A ...
- fiddler选项卡-Statistc(统计)
Statistc Statistc是fiddler用来对session列表里的Session相关情况的统计,利用这个选项,可以对请求进行性能以及其他数据分析 1.界面 2.参数详解 建议:打开fidd ...
- springboot——发送put、delete请求
在springmvc中我们要发送put和delete请求,需要先配置一个过滤器HiddenHttpMethodFilter,而springboot中,已经帮我们自动配置了,所以我们可以不用配置这个过滤 ...
- 剑指 Offer 04. 二维数组中的查找
链接:https://leetcode-cn.com/problems/er-wei-shu-zu-zhong-de-cha-zhao-lcof/ 标签:数组.双指针.二分 题目 在一个 n * m ...
- 分分钟教你Python Web开发框架Django
Python除了爬虫.深度学习(人工智能).数据分析等外,还可以用来开发网站系统,如我们常见的知乎,豆瓣等都是用Python开发的网站系统. 今天辰哥就来教大家如何新建属于自己的Django项目,让D ...