• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >ASP.NET > ADO.NET基础知识汇总

ADO.NET基础知识汇总

作者:$(helloworld) 字体:[增加 减小] 来源:互联网 时间:2017-05-11

$(helloworld)通过本文主要向大家介绍了ado.net基础教程,ado.net,ado.net是什么,ado.net连接数据库,ado.net视频教程等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

虽然我们都知道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;";
</div>

或者

String connectString = "Server =myServerAddress;Database = myDataBase; User Id = myUsername; Password = myPassword;";
</div>

注意:对于Sql Server来说,它支持两种身份验证方法,一种是windows身份验证,另一种是Sql Server身份验证。如果要用windows身份验证,就需要在连接字符串中包括Integrated Security属性。该属性默认为False。需要设置为True后才能使用windows身份验证。
除了这几个必须的字段,连接字符串中还有许多可选的属性,在这里我就不一一列举,列出一些相关资料供感兴趣的朋友自行查阅,一个连接字符串可以包含哪些属性(http://www.weikejianghu.com/article/67742.htm)。

接着,有了连接字符串就可以创建连接对象了。

SqlConnection connection = new SqlConnection(connecString);
或者可以使用专门的连接字符串生成器:

SqlConnectionStringBuilder connectionStringBuilder = new SqlConnectionStringBuilder()
{
DataSource=”“,
InitialCatalog=”“,
UserID=”“,
Password=””
};
SqlConnection connection = new SqlConnection(connectionStringBuilder.ToString());
</div>

然后使用连接对象可以打开或关闭连接。

connection.Open();
connection.Close();

执行命令

打开连接之后就可以操作数据库了,在这里需要用到SqlCommand命令对象。
它具有四个主要属性,这些属性会在初始化的时候赋默认值:
CommandText:空字符串(”“)
CommandTimeout:30
CommandType:CommandType.Text
Connection:Null

创建命令对象:

SqlCommand command = connection.CreateCommand(); 
</div>

或

SqlCommand command = new SqlCommand();
</div>

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();)
    }
  }
 }
}

</div>

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);//可以放一个参数数组,包含多条参数,在此只举一个例子
}

</div>

可以通过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();
  }
 }
}

</div>

介绍几个常用的方法:

GetOrdinal:可以获取指定列名的序列号,int name = dr.GetOrdinal(“name”);
GetName:与上面的方法对应,可以通过列号返回列名字。
IsDBNull:判断当前读取的数据是否为Null。
NextResult:当查询为批处理查询时,使用这个方法去获取

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • ADO.NET基础知识汇总
  • ADO.NET编程之基础知识

相关文章

  • 2017-05-11我今天开始正式学习.net遇到的问题
  • 2017-05-11JQuery实现Repeater无刷新批量删除(附后台asp.net源码)
  • 2017-05-11ASP.NET编程中经常用到的27个函数集
  • 2017-05-11asp.net实现在线音乐播放器示例
  • 2017-05-11ASP.NET中动态控制RDLC报表
  • 2017-05-11如何禁止文本框的记忆功能方法集锦
  • 2017-05-11c#实现根据网络IP显示地理位置功能示例
  • 2017-05-11ASP.NET缓存管理的几种方法
  • 2017-05-11ASP.NET网站实时显示时间的方法
  • 2017-05-11.NET程序集引用COM组件MSScriptControl遇到问题的解决方法

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • ASP.NET动态增加HTML元素的方法实例小结
    • asp.net Linq To Xml上手Descendants、Elements遍历节点
    • .net动态显示当前时间(客户端javascript)
    • 一个ASP.NET的MYSQL的数据库操作类自己封装的
    • ASP.NET存储过程实现分页效果(三层架构)
    • HTTP协议下用Web Service上传大文件的解决方案
    • asp.net通过js实现Cookie创建以及清除Cookie数组的代码
    • asp.net 两个不同页面的传值
    • 让Asp.NET的DataGrid可排序、可选择、可分页
    • 蛇年多屏图片切换(可添加图片链接以及编辑标题)

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有