虚拟主机行业最新资讯 虚拟主机评测对比 互联网最新动态 技术学院 站长资讯 在线教程 网站运营
搜索优化 服务器 网络编程 图形图象 站长之家 网页制作 操作系统
冲浪宝典 软件教学 视频通信 办公软件 邮件系统 网络安全 认证考试
您当前位置:站长资讯>-> 网站运营-> 网站运营
运用.NET+SQL Server2005构建多层网站(3)-.NET教程,数据库应用
作者:网友供稿 点击:146
  西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!虚拟主机可在线rar解压,自动数据恢复设置虚拟目录等.虚拟主机免费赠送访问统计,企业邮局.Cn域名注册10元/年,空间150元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金!
文章页数:[1] 
利用tableadapter configuration wizard创建数据访问层

  在visual studio 2005 中,新增了tableadapter configuration wizard来很方便地创建数据访问层。首先,我们了解下什么是tableadapter。一个tableadapter连接到数据库,执行查询语句或者存储过程,并且将返回的结果集填充到datatable中去。tableadapter configuration 向导允许你以类型化dataset方式创建编辑数据集合,十分方便。

    首先选用c#语言,创建一个名为ntierexample的web项目,为了创建数据访问层,首先鼠标右键点选工程项目菜单,在弹出的菜单中选择"add new item"。在弹出的"add new item"对话框中,选择"dataset"类型。然后在文件名中,输入"authors.xsd",并点击"add"。

  当你点"add"的按钮时 ,系统会提示是否将该文件放到app_code目录中去,因为vs.net 2005中,一般会将数据访问层的文件放到该文件夹中去,以方便管理。我们继续选"ok",将xsd文件放到app_code文件夹中去。接下来,就出现"tableadpater"设置向导的窗口了。

首先,我们要指定连接的数据库字符串,并选择将连接字符串保存到web.config文件中去,并选"next"进入下一步。在该步中,选择命令类型,由于我们刚才建立了存储过程,因此选择"use existing store procedure",再点选"next",进入下一个窗口,会询问采用哪一个存储过程,这里,我们选择使用"getauthors"这个存储过程,再选"next"进入下一步,在这里,我们要指定使用getauthors存储过程的哪一个方法用来返回数据集,我们选择"return a datatable"的选现,并指定使用其中的getauthors方法,以datatable的形式返回。继续选"next",则系统自动会生成数据访问层了。

  当你点击"finish"按钮后,visual studio 会自动产生一些类,当这些类产生后,我们将类改名为authors,这样,接下来,我们按上面的步骤,类似地,使用"tableadapter"向导,选择工具菜单栏的"data-add-tableadapter",再次增加一个tableadapter,这次选择的是"gettitlesbyauthor"存储过程,而选择返回的方法是"gettitlesbyauthor",其他步骤和生成"getauthos"的一样,最后,将产生的类的名改为"authortitles"。创建逻辑层

  接下来,我们创建逻辑层,在这个例子中,逻辑层是十分简单的,只是起到说明作用。首先,我们新建一个类authrobiz类,并将其放在app_code文件夹中,并将类的代码修改如下:

public class authorsbiz
{
 public authorsbiz()
 {}

 public datatable getauthors()
 {
  authorstableadapters.authorstableadapter authordb = new authorstableadapters.authorstableadapter();
  return authordb.getauthors();
 }
 public datatable getauthortitles(string authorid)
 {
  authorstableadapters.authortitlestableadapter authordb = new authorstableadapters.authortitlestableadapter();
  return authordb.gettitlesbyauthor(authorid);
 }
}




  从上面的代码中,可以看到,我们刚才通过向导创建的"authors.xsd"类型化dataset类,现在

在代码中,可以通过使用authorstableadapters类来调用,其中authordb是authorstableadapters类的实例。



  创建表示层



  在asp.net 2.0中,在创建表示层时,可以使用master-page技术,使得可以很方便地构建页面。mater-page的意思是,可以首先构建出一个页面的主框架模版结构,然后在其中放置一个contentplaceholder控件,在该控件中,将展现其他子页面的内容。在其他子页面中,只需要首先

引用该master页面,然后再修改contentplaceholder控件的内容就可以了。



  首先,在工程中新增加一个"master"类型的文件,将其命名为commonmaster,然后输入以下代码:



<%@ master language="c#" %>
<html>
 <head id="head1" runat="server">
  <title>master page</title>
 </head>
<body>
<form id="form1" runat="server">
 <table id="header" style="width: 100%; height: 80px" cellspacing="1" cellpadding="1" border="1">
 <tr>
  <td style="text-align: center; width: 100%; height: 74px;" bgcolor="teal">
   <asp:label runat="server" id="header" font-size="12pt" font-bold="true">
     authors information
   </asp:label>
  </td>
 </tr>
 </table>
 <b/>
 <table id="leftnav" style="width: 108px; height: 100%" cellspacing="1" 
cellpadding="1" border="1">
 <tr>
  <td style="width: 100px">
   <table>
    <tr>
     <td>
      <a href="home.aspx">home</a>
     </td>
    </tr>
    <tr>
     <td>
      <a href="authors.aspx">authors list</a>
     </td>
    </tr>
   </table>
  </td>
 </tr>
 </table>
 <table id="mainbody" style="left: 120px; vertical-align: top; width: 848px;
 position: absolute; top: 94px; height: 100%" border="1">
  <tr>
   <td width="100%" style="vertical-align: top">
    <asp:contentplaceholder id="middlecontent" runat="server"></asp:contentplaceholder>
   </td>
  </tr>
 </table>
</form>
</body>
</html>




  接下来,我们首先创建以显示作者页面的authors.aspx页面,由于页面的框架要保持一直,

因此,可以利用maser-page技术,在新建页面时,引入刚才建立的commonmaster页面,

点add按钮后,选择刚才建立的commonmaster页面,再输入如下代码:



<%@ page language="c#" masterpagefile="~/commonmaster.master" %>
<asp:content id="content1" contentplaceholderid="middlecontent" runat="server">
<asp:objectdatasource runat="server" id="authorssource" typename="authorsbiz" selectmethod="getauthors">
</asp:objectdatasource>
<asp:gridview runat="server" autogeneratecolumns="false" id="authorsview" datasourceid="authorssource"> 
 <alternatingrowstyle backcolor="silver"></alternatingrowstyle>
<columns>
<asp:hyperlinkfield datatextfield="au_id" headertext="author id" datanavigateurlfields="au_id" 
datanavigateurlformatstring="authortitles.aspx?authorid={0}">
</asp:hyperlinkfield>
<asp:boundfield headertext="last name" datafield="au_lname"></asp:boundfield>
<asp:boundfield headertext="first name" datafield="au_fname"></asp:boundfield>
<asp:boundfield headertext="phone" datafield="phone"></asp:boundfield>
<asp:boundfield headertext="address" datafield="address"></asp:boundfield>
<asp:boundfield headertext="city" datafield="city"></asp:boundfield>
<asp:boundfield headertext="state" datafield="state"></asp:boundfield>
<asp:boundfield headertext="zip" datafield="zip"></asp:boundfield>

</columns>
</asp:gridview>
</asp:content>




  注意,其中我们用到了objectdatasource控件,在.net 2.0中,有了该控件,可以很方便地

沟通表示层和逻辑层。其中的代码如下:

<asp:objectdatasource runat="server" id="authorssource" typename="authorsbiz" selectmethod="getauthors">
</asp:objectdatasource>




  其中的typename属性指定为我们之前创建的逻辑层的类authorsbiz类,而为了获得数据,采用了selectmethod方法,这里指定了之前建立的getauthors方法。当然,也可以在其他场合,应用updatemethod,insertmethod,deletemethod方法,也可以加上参数,比如接下来要创建的authortitle.aspx页面,代码如下:



<%@ page language="c#" masterpagefile="~/commonmaster.master" %>
<asp:content id="content1" contentplaceholderid="middlecontent" runat="server">
<asp:objectdatasource runat="server" id="authortitlessource" typename="authorsbiz" selectmethod="getauthortitles">
<selectparameters>
 <asp:querystringparameter type="string" direction="input" name="authorid" querystringfield="authorid" />
</selectparameters>
</asp:objectdatasource>
<asp:gridview runat="server" id="authortitlesview"
 datasourceid="authortitlessource">
 <alternatingrowstyle backcolor="silver"></alternatingrowstyle>
</asp:gridview>
</asp:content>




  上面的代码中,首先用户在authors.aspx页面点选某个作者名时,则在authortitle.aspx页面中,返回该作者的所有著作。所以,在objectdatasource控件中,我们使用了selectparameters参数,

指定传入来要查询的参数是authorid。最后,再将gridview绑定到objectdatasource控件中去。



  最后,运行我们的代码。



  小结



  在asp.net 2.0中,我们利用sql server 2005的强大功能,可以利用.net 语言创建存储过程,并使用tableadapter向导,很方便地创建数据访问层,再利用objectdatasource控件的特性,可以很

方便地沟通表示层和逻辑层。
文章整理:西部数码--专业提供域名注册虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!
文章页数:[1] 
相关主题
  • 运用.NET+SQL Server2005构建多层网站(2)-.NET教程,数据库应用
  • 运用.NET+SQL Server2005构建多层网站(1)-.NET教程,数据库应用
  • Google

    热门文章
    ·ASP.NET的安装与运行环境-.NET教程,Asp.Net开发
    ·运用.NET+SQL Server2005构建多层网站(3)-.NET教程,数据库应用
    ·JAVA写的四则混合运算-JSP教程,Java技巧及代码
    ·获取高精度的时间差,可以用来分析页面运行时间的长短-.NET教程,Asp.Net开发
    ·基于.Net平台应用程序唯一运行实例C#代码实现-.NET教程,C#语言
    ·Alexa 世界网站排名研究(下)-网站运营,搜索引擎推广
    ·运用.NET+SQL Server2005构建多层网站(1)-.NET教程,数据库应用
    ·优化系统让Photoshop运行更流畅-网页设计,Photoshop
    ·ASP.NET 2.0运行时简要分析-.NET教程,Asp.Net开发
    ·手工打造运算符重载过程-.NET教程,C#语言

    最新文章
    ·MySQL服务器内部安全数据目录访问
    ·MySQL和SQL Server,到底选择谁?
    ·五种推广模式的优劣的比较
    ·基于.Net平台应用程序唯一运行实例C#代码实现-.NET教程,C#语言
    ·运用反射给实体赋值-.NET教程,Asp.Net开发
    ·大数运算(一)-.NET教程,评论及其它
    ·虚拟主机上asp.net运行权限不足问题及解决-.NET教程,Asp.Net开发
    ·ASP.NET底层架构探索之进入.NET运行时-.NET教程,Asp.Net开发
    ·基于.Net平台应用程序唯一运行实例实现-.NET教程,.NET Framework
    ·ASP.NET 2.0运行时简要分析-.NET教程,Asp.Net开发

    相关主题
  • 运用.NET+SQL Server2005构建多层网站(2)-.NET教程,数据库应用
  • 运用.NET+SQL Server2005构建多层网站(1)-.NET教程,数据库应用



  • 友情链接
    CNNIC 西部数码
    万网 自助建站
    虚拟主机 asp空间
    域名注册 域名
    域名申请 主页空间
    论坛空间 网站空间
    国际域名 虚拟空间
    空间租用 DDOS防火墙
    成都主机托管 四川主机托管
    主机租用 服务器租用
    网站目录 一班在线
    虚拟主机 网址大全
    软件下载
    自助链接
    虚拟主机资讯 特价虚拟主机


    版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!

    特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
      打印  刷新  关闭


    联系我们  |  广告服务  |  免责声明  |  友情连接
    Copyright ?2005 - 2006 All Rights Reserved
    蜀ICP备05000045号