【Asp.Net】——ADO.NET为访问数据插上了翅膀

【前言】
前面在介绍asp.net的软件要求的时候提到了MDAC的安装,其实安装它的目的就是为了让我们更加安全,便利的访问数据库,它的实质就是为asp.net的程序提供了访问数据库的ADO.NET.
【内容】
1. Ado.Net的概念
一组向 .NET Framework 程序员公开数据访问服务的类。它为创建分布式数据共享应用程序提供了一组丰富的组件。它提供了对关系数据XML 和应用程序数据的访问, ADO.NET 支持多种开发需求,包括创建由应用程序、工具、语言或 Internet 浏览器使用的前端数据库客户端和中间层业务对象。
2. Ado.Net的发展

在ADO.NET之前,发展的访问数据库的对象无论是DAO,RDO,ADO,访问数据库的时候都是提供了一组用户接口,而且对于数据库的访问是建立在连接的状态下的。
ADO.NET的XML技术介绍:
【Asp.Net】——ADO.NET为访问数据插上了翅膀_第1张图片
业务层负责了与基本层中数据存储进行通信,然后构造了dataset。将dataset以xml模式传递会用户接口。由于dataset是数据的内存副本,所以它也存放在数据要传递会的客户机的内存中。进而实现了由应用程序访问数据库的快速方式。
从上面可以看出从ADO.NET开始,对数据库的访问就发生了革命性的变化:

形式 进步
内存数据表现形式 独立表向dataset所包含的多个表过度
处理表的方式 由join合并表向dataRelation对象处理查询
数据导航 由顺序扫向非顺序过度
访问方式 由连接访问向已断开访问过度
共享方式 由执行类型转换向xml格式过度
伸缩性 由长时间的锁定和保持数据库向短时间过度

内存中数据表现形式 由独立的表向dataset所包含的一个或多个表过度
处理表关系 由join合并表向datarelation对象处理查询
数据导航 由顺序扫面向非顺序过度
访问方式 由连接访问向已断开访问过度
共享方式 由执行类型转换向xml格式无限制传送过度
伸缩性 由长时间的锁定和保持数据库向短时间过度
3.ADO.Net的组成:
【Asp.Net】——ADO.NET为访问数据插上了翅膀_第2张图片

Connections. 用于连接和管理针对数据库的事务。
Command: 用于发出针对数据库的SQL指令。分为了sqlcommand和 oledbcommand。
DataReaders:用于从SQL Server数据源读取只进流的数据记录。
DataSets: 用于针对结构型数据,XML数据和关系型数据的存储,远程处理和编程。
DataAdapters:用于推送数据到DataSet,并针对数据库协调数据。
Connections示例:

public sqlhelp()
        {
            string connStr = @"server=CYL520;database=newsystem;User ID=sa;PWD=1"; 
            using (SqlConnection connection = new SqlConnection(connStr))
            {
                connection.Open();   
            }
        }`

SQLcommand示例:

        /// <summary>
        /// 该方法执行的传入的是sql语句。
        /// </summary>
        /// <param name="cmdtext">执行sql语句或者是存储过程!</param>
        /// <returns></returns>
 public DataTable ExecuteQuery(string cmdtext,CommandType ct)
        {
            DataTable dt = new DataTable(); //定义了一个表
            cmd = new SqlCommand(cmdtext , getConn());
            cmd.CommandType = ct;
            using (sdr = cmd.ExecuteReader(CommandBehavior.CloseConnection))
            {
                dt.Load(sdr);
            }

            return dt;
        }

DataReader示例:

        /// <summary>
       ///返回datareader对象
       /// </summary>
       /// <returns></returns>
        public SqlDataReader  sqlc()
        {  
            CommandType ct=CommandType.Text;
            string cmdtext = "select * from Category";
            SqlCommand cmd = new SqlCommand(cmdtext,createconnection());
            SqlDataReader dr = new SqlDataReader();
            dr=cmd.ExecuteReader ();

        }

SQLdataAdapter示例:

       /// <summary>
       /// 适配器sqldataadapter
       /// </summary>
       /// <returns></returns>
       public DataTable  sqlB()
       {
           SqlDataAdapter sda=new SqlDataAdapter();
           sda.SelectCommand=new SqlCommand("select * from person",createconnection());
           DataSet ds = new DataSet();
           DataTable dt=new DataTable ();
           sda.Fill(ds,"person");
           return ds.Tables["person"];

       }

你可能感兴趣的:(【Asp.Net】——ADO.NET为访问数据插上了翅膀)