`

收藏:ASP.NET讲座(5)-数据库的操作ADO.NET

阅读更多
自若干年前推出开放式数据库连接 (ODBC) 应用程序编程接口 (API) 以来,出现了各种各样的数据库访问技术,而 ADO.NET 是其中最新的一种。在这过程中,发生了许多有趣的事。例如,COM 闯入数据库领域,开始培植 OLE DB 的殖民进程。然后,大致相当于 OLE DB 自动化版本的 ActiveX? Data Objects (ADO) 被选来统治 Windows? 数据库开发者的 Visual Basic? 和 ASP 社区。

  通过 .NET,Microsoft 正在提供通用框架(即 Framework Class Library),其中将包括所有现有的 Windows API 甚至更多的内容。特别值得一提的是,它包括大量常用的库,而这些库现在需要通过各个 COM 对象分别获得。在这些库中,您会发现 XML 和 ADO 对象模型,它们被集成到了叫做 ADO.NET 的类子树中。

  ADO.NET 事实上成为构建数据感知 .NET 应用程序的基础。和 ADO 不同的是,ADO.NET 遵循更通用的原则,不那么专门面向数据库。ADO.NET 集合了所有允许数据处理的类。这些类表示具有典型数据库功能(如索引、排序和视图)的数据容器对象。尽管 ADO.NET 是 .NET 数据库应用程序的权威解决方案,但从总体设计上来看,它不象 ADO 模型那样以数据库为中心,这是 ADO.NET 的一大特点。

  ADO.NET 与 ADO 有很大差异。ADO.NET 是新的数据访问编程模型,需要开发人员的全面理解、投入和新思维。然而,一旦开始掌握 ADO.NET,您将意识到:原有的 ADO 技巧非常有助于您以不同、却更巧妙和可靠的方式来创建有效的应用程序和解决各种老问题。
(以上译自 Microsoft .NET部一位官员的讲话)

  5.1 目前的ADO.net

  目前 ADO.NET 提供了两种托管提供程序:一种用于 SQL Server 7.0 或更高版本,另一种用于其他所有您可能已经安装的 OLE DB 提供程序。在这两种情况下您分别使用不同的类,但遵循相似的命名规则。除前缀外,名称都是相同的。前一种情况前缀为 SQL,后一种情况则是 ADO。

<% @ Import Namespace="System.Data.ADO" %>
<% @ Import Namespace="System.Data.SQL" %>

  您应该使用 SQL 类访问 SQL Server 表,因为它们直接进入数据库服务器的内部 API,跳过了由 OLE DB 提供程序表示的中间层。ADO 类是 OLE DB 提供程序上的 .NET 接口,它们使用 COM Interop 桥进行工作。

  5.2 连接一个数据库

Dim myConnection As New
 SQLConnection("server=localhost;uid=sa;pwd=;database=pubs")
Dim myCommand As New
 SQLDataSetCommand("select * from Authors", myConnection)

或者
 SQLConnection myConnection = new SQLConnection();
 myConnection.DataSource = "localhost";
 myConnection.UserID = "sa";
 myConnection.Password = "";
 myConnection.ConnectionTimeout = 30;
 myConnection.Open();
 myConnection.Database = "pub";
 myConnection.IsolationLevel = IsolationLevel.ReadCommitted
  

  这里我们需要讲述一下Connection的方法和属性了。

  ConnectionTimeout超时

  DataBase 缺省数据库

  DataSource DNS

  UserID 原来叫UID

  Password

  State 取得目前连接的状态

  Open() 打开

  Close() 关闭
  5.3 操作数据库

  通过一个Command对象,我们才可以对数据库进行操作

Dim myConnection As SQLConnection = New SQLConnection("server=localhost;uid=sa;
pwd=;database=pubs")
Dim myCommand As SQLCommand = New SQLCommand("select * from Authors", myConnection)
myConnection.Open()
Dim dr As New SQLDataReader
myCommand.Execute(dr)

...

myConnection.Close()

或者 这样做
Dim myConnection As New SQLConnection("server=localhost;uid=sa;pwd=;database=pubs")
Dim mycommand As New SQLCommand( _
"UPDATE Authors SET phone='(800) 555-5555' WHERE au_id = '123-45-6789'", _
myConnection)
myCommand.ActiveConnection.Open()
myCommand.ExecuteNonQuery()
myCommand.ActiveConnection.Close()


  这些都是SQLCommand的标准用法,下面列出了Command的所有属性和相关方法。

  ActiveConnection 取得或设置联结Connections

  CommandText 执行的SQL语句或储存过程(StoredProcedure)名

  CommandTimeout 超时

  CommandType Command操作的类型(StoredProcedure,Text,TableDirect)三种,默认Text

  Parameters 操作储存过程时使用

  Execute() 执行SQL语句或储存过程

  ExecuteNonQuery() 同上,但无返回,或者说,只返回记录的数量

  注意: 和ASP一样,在运行完以后一定要注意关闭Connection,否则会很耗服务器资源的。

  5.4 数据的显示

  在这节的讲解前,我们先建立一个数据库,名字叫 aspnet 然后里面有一张表user 结构如下:
uid username Email
1  User1 Mail1
2  User2 Mail2
3  User3  Mail3


  SQL 语句 Select * From User

  数据库语句 server=localhost;uid=sa;pwd=;database=aspnet

  5.4.1 用 DataReader 方法显示数据

  有两种方法可以显示数据 DataReader方法,和DataSet方法,而DataReader只能储存查询数据,我们先讲用DataReader方法显示

<script language="VB" runat="server">
 Sub Page_Load(Src As Object, E As EventArgs)
  Dim MyConnection As SQLConnection =
     New SQLConnection("server=localhost;uid=sa;
               pwd=;database=aspnet")
  Dim MyCommand As SQLCommand =
     New SQLCommand("select * from User", MyConnection)
  MyConnection.Open()
  Dim DR As SQLDataReader
  MyCommand.Execute(DR)
  MyDataGrid.DataSource = DR
  MyDataGrid.DataBind()
  MyConnection.Close()
 End Sub
</script>
<ASP:DataGrid id="MyDataGrid" runat="server"
   Width="700"
   BackColor="#ccccff"
   BorderColor="black"
   ShowFooter="false"
   CellPadding=3
   CellSpacing="0"
   Font-Name="Verdana"
   Font-Size="8pt"
   HeaderStyle-BackColor="#aaaadd"
/>

  对于显示的控制,大家可以复习一下前一讲,数据的绑定,其实多联系也是一种很好的方法。

  在定制显示中,还有一种比较使用的方法,而不用绑定

Dim DR As SQLDataReader

  DR["字段名"]的方法也可以取到数据

  5.4.2 用 DataSet 方法显示数据

  用DataSet记录的数据其实就是一个表,而对表的操作,只是对DataSet的操作,并没有改变数据库,而要到DataSet更新的时候,才完整的写入数据库,这个往往是新手容易忽视的地方。

<%@ Import Namespace="System.Data" %>
<%@ Import Namespace="System.Data.SQL" %>

<html>
<script language="VB" runat="server">

 Sub Page_Load(Src As Object, E As EventArgs)

  Dim DS As DataSet
  Dim MyConnection As SQLConnection
  Dim MyCommand As SQLDataSetCommand
  
  MyConnection = New
   SQLConnection("server=localhost;uid=sa;pwd=;database=aspnet")
  MyCommand =
   New SQLDataSetCommand("select * from User",MyConnection)

  DS = new DataSet()
   ~~~初始化DataSet()
  MyCommand.FillDataSet(ds, "User")
   ~~~FillDataSet顾名思义把整个查询内容储存进DataSet中
  MyDataGrid.DataSource=ds.Tables("User").DefaultView
  MyDataGrid.DataBind()
   ~~~绑定数据
 End Sub
</script>
<body>

 <h3><font face="Verdana">
  Simple Select to a DataGrid Control
</font></h3>

<ASP:DataGrid id="MyDataGrid" runat="server"
  Width="700"
  BackColor="#ccccff"
  BorderColor="black"
  ShowFooter="false"
  CellPadding=3
  CellSpacing="0"
  Font-Name="Verdana"
  Font-Size="8pt"
  HeaderStyle-BackColor="#aaaadd"
  MaintainState="false"
/>

</body>
</html>
  5.5 数据的添加,修改,和删除

  其实他们是在就是简单的不要再简单的东西。

  添加:

DataRow dr=SQLDataSet.Tables["User"].NewRow();
dr["id"] = "4";
dr["username"] = "user4";
dr["Email"] = "mail4";
SQLDataSet.Tables.Rows.Add(dr);
修改:
SQLDataSet.Tables["user"].Rows[3]["username"]= "user5"
删除:
SQLDataSet.Tables["user"].Rows[3].Delete()
修改完之后,必须更新数据库
SQLCommand.Update(SQLDataSet, "user")

  5.6 关于显示中的分页问题

  这个问题,一再在论坛中给众人提出过,曾经是ASP中,一个比较难解决的问题,不过在ASP.net中,只不过是DataGrid的一个属性而已。

  AllowPaging="True" 是否支持分页

  PageSize="10" 每页显示多少

  PagerStyle-HorizontalAlign="Left" 分页显示的定位

  完整的例子:

<asp:DataGrid id="dataGrid1" runat="server"
  BorderColor="black"
  BorderWidth="1"
  GridLines="Both"
  CellPadding="3"
  CellSpacing="0"
  HeaderStyle-BackColor="#aaaadd"
  AllowPaging="True"
  PageSize="10"
  PagerStyle-HorizontalAlign="Left"/>
分享到:
评论

相关推荐

    微软MSDNWebCAST_ASP.NET系列讲座-01ADO.NET开发最佳实践

    【标题】"微软MSDNWebCAST_ASP.NET系列讲座-01ADO.NET开发最佳实践"是一场由微软主办的专业技术讲座,主要针对ASP.NET开发者,由邵志东先生主讲。这场讲座的核心内容是探讨ADO.NET在实际开发中的高效、稳定和最佳...

    asp.net 教程 ppt

    7. **数据访问**:ASP.NET提供了ADO.NET库来与数据库交互,同时也支持Entity Framework等ORM(对象关系映射)工具,简化了数据库操作。 8. **部署和配置**:学习如何在IIS(Internet Information Services)上部署...

    ASP.NET与网络数据库开发培训教程

    在ASP.NET中,通常使用ADO.NET作为数据访问层,它提供了与各种数据库(如SQL Server、Oracle、MySQL等)交互的接口。ADO.NET包括DataSet、DataTable、DataAdapter等组件,它们允许在客户端和服务器之间离线操作数据...

    ADO.NET数据操作 PDF

    讲座内容: ADO.NET的出现对于ASP.NET编程人员来说是非常大的一个变革,由于它的出现,使得ASP.NET程序员对数据库的操作更加的方便和快捷,它支持各种常见的数据库操作、并且对数据库的各种添加、删除、修改、...

    ADO.NET数据操作 Demo

    讲座内容: ADO.NET的出现对于ASP.NET编程人员来说是非常大的一个变革,由于它的出现,使得ASP.NET程序员对数据库的操作更加的方便和快捷,它支持各种常见的数据库操作、并且对数据库的各种添加、删除、修改、...

    ASP.NET与Web Service实例剖析

    3. **ASP.NET Data Access**:ASP.NET提供了多种数据访问方法,如ADO.NET,使得开发者可以方便地与数据库进行交互。 4. **ASP.NET Configuration**:配置系统允许开发者通过配置文件轻松管理应用程序设置,而无需...

    ADO.NET数据操作 Video.part2

    讲座内容: ADO.NET的出现对于ASP.NET编程人员来说是非常大的一个变革,由于它的出现,使得ASP.NET程序员对数据库的操作更加的方便和快捷,它支持各种常见的数据库操作、并且对数据库的各种添加、删除、修改、...

    ADO.NET数据操作 Video.part1

    讲座内容: ADO.NET的出现对于ASP.NET编程人员来说是非常大的一个变革,由于它的出现,使得ASP.NET程序员对数据库的操作更加的方便和快捷,它支持各种常见的数据库操作、并且对数据库的各种添加、删除、修改、...

    苏鹏asp.net讲座datasourse

    数据源控件是ASP.NET中一个核心的概念,它们提供了一种方便的方式来连接和操作数据库,而无需编写大量的SQL代码或ADO.NET对象。这些控件包括SqlDataSource、AccessDataSource、ObjectDataSource、XmlDataSource等,...

    ASP.NET基础知识ppt

    本讲座主要围绕ASP.NET的基础知识展开,涵盖了DOM、DotNet和ADO.NET等多个核心概念。 首先,DOM(Document Object Model)是HTML和XML文档的编程接口,它将网页或文档表示为树形结构,允许程序和脚本动态更新、添加...

    asp.net网络开发指南(PPT)

    6. **数据访问技术**:包括ADO.NET,Entity Framework等,演示如何与数据库交互,执行CRUD操作,以及数据绑定技术。 7. **Web服务和API**:讲解如何创建和使用Web服务(如SOAP和RESTful API),以及如何集成外部...

    asp.net课件

    5. **数据访问**:使用ADO.NET或Entity Framework进行数据库交互,了解ORM(对象关系映射)的概念和实践。 6. **身份验证与授权**:学习如何在ASP.NET中实现用户登录、注册、角色管理和权限控制。 7. **状态管理**...

    ASP.net_3

    以及数据库交互,如Entity Framework或ADO.NET。 综上所述,这个“ASP.NET_3”教程将覆盖ASP.NET中的外观管理、布局设计、用户体验优化等多个核心主题,并通过多元化的教学材料帮助学习者深入理解和掌握这些关键...

    ASP.NET Web开发学习实录光盘

    使用ADO.NET或Entity Framework可以方便地与SQL Server、MySQL等数据库进行交互。在光盘的项目中,你可能会看到如何设计数据库模型,如何执行CRUD操作,以及如何进行复杂的查询。 此外,光盘中的视频教学讲座虽然未...

    关于NET技术方面的讲座

    4. **ADO.NET**:它是.NET与数据库交互的桥梁,提供了数据访问组件,使得开发者可以方便地操作数据库。 5. **WPF(Windows Presentation Foundation)**:用于构建Windows桌面应用的UI框架,支持丰富的图形和媒体...

    深入.net平台和c#编程PPT-02

    5. **ASP.NET Web开发**:如果PPT深入到Web应用开发,那么ASP.NET将是重要的讨论点。它是一个用于构建Web应用程序的框架,支持MVC模式、Web Forms和Core版本,允许开发人员构建高性能、可伸缩的网站。 6. **Windows...

    ASP.NET实战编程(五).zip

    【ASP.NET实战编程(五)】的压缩包包含了一个名为"WebCast20061215am_Video.wmv"的视频文件,这很可能是一个关于ASP.NET技术的在线讲座或教学视频。ASP.NET是微软公司推出的一种用于构建动态网站、web应用程序和web...

    asp.net 实例编程

    通过ADO.NET,我们可以方便地连接数据库,执行SQL语句,实现数据的增删改查。同时,使用DataSet、DataTable等对象可以实现离线数据操作。 在实例编程中,我们还会涉及到ASP.NET的身份验证和授权机制,例如, Forms ...

    ASP.NET-[学校班级]谷秋精品课程软件课程版v2.7.zip

    在"ASP.NET-[学校班级]谷秋精品课程软件课程版v2.7_guqiu27.rar"中,我们可以期待找到一系列关于ASP.NET的教程资料,可能包括视频讲座、PPT课件、源代码示例以及练习项目。学习这些内容,学生和开发者可以了解ASP...

    ASP系列新手讲座--初学必看的哦

    此外,ASP还有许多内置组件和第三方库可供扩展,例如ASP.NET(后来取代了ASP),它提供了更强大、更现代的Web开发框架。不过,对于初学者来说,掌握ASP的基础至关重要,因为这将为后续的学习打下坚实基础。 总之,...

Global site tag (gtag.js) - Google Analytics