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 结构如下:
UIDUSERNAMEEMAIL
1 USER1MAIL1
2 USER2MAIL2
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"/>