我的一亩三分地 我就喜欢!
13fen  设为主页
 收藏本站
 
当前位置: > 一亩三分地:首页 > 网络学院 > 网络编程 > net专区 > ASP.NETTips1---合并多个字段值
热门文章排行
热门文章排行 检查email地址格式的代码(01-11)
PHP操作文件问答(01-11)
PHP安装攻略:安装并配置PHP(10-23)
PHP的十个高级技巧 4(10-23)
关于APE的介绍、播放及制作(03-22)
精采文章排行
精采文章排行 ASP.NET与MySQL数据库简明图示入门教(11-16)
ASP.NET与MySQL数据库简明图示入门教(11-16)
ASP.NET 链接数据库基础(11-16)
webconfig的设置节点说明(11-16)
部署ASP.NET的三大技术(上)(11-16)
技术专题推荐
网管论坛交流
 

ASP.NETTips1---合并多个字段值 

作者:佚名   来源:Linux 宝库   点击:   日期:2006-12-22

  一般支持数据绑定的web控件,例如DorpDownList控件、CheckBoxList控件等,都包含五个属性:DataSource、DataMember,DataTextField、DataValueField和DataTextFormatString.DataSource用于获取数据源,亦即获取包含数据的集合;其他四个属性用于获取数据源中的一个字段值。然而,通常情况下,你想将这些数据源中的多个字段值绑定在一起赋值给其中的一个属性,这是不能直接实现的。下面我们将介绍两种方法用于实现这一功能。


  以上限制在于不能将多个字段值绑定在一起,赋值给这四个属性中的其中一个;但是SQL语句却完全没有这种限制。所以,我们的第一个方法是使用SQL语句将源表中的两个或多个字段值绑定在一起,使用AS子句传递给另一个字段,这样就实现了一个字段包含多个字段值。由于现在一个字段就包含了多个字段的值,我们将其赋值给web控件的那四个属性时就不用有更多的考虑了。我们可以参考下面的语句看看这种方法的妙处:


  strCmd="SELECT employeeid,lastName +','+firstName AS 'EmployeeName' FROM Employees";


  这种方法十分简洁,也是最直接的一种方法,不过存在着效率不足的问题,而且有可能会产生重复数据。下面我们介绍另一种方法,我们可以将源表填充到一个数据集DataSet中,然后将数据集的数据放置到一个数据表DataTable中,然后给该表创建一个新列,该列由源表中的两个或多个字段构成,这样我们也实现了多个字段值的绑定。下面的语句可以说明这种方法的实现:


  dt.Columns.Add(“EmployeeName”,typeod(String),“lastName+‘,’+firstName”);


  后一种方法的缺点在于创建新列的开销。不过这种方法条理比较清楚,而且不会产生重复数据的可能,建议使用这种方法。


  为了说明这两种方法,下面的代码将两种方法放在一起实现了:


  // 在此处放置用户代码以初始化页面


  string strConn,strCmd;


  strConn="DATABASE=NorthWind;SERVER=localhost;UID=sa;PWD=99133009;";


  //如果既需要将firstName和LastName绑定,又需要单独使用他们,下面的语句就会产生重复数据。


  strCmd="SELECT employeeid,firstName,lastName,lastName +','+firstName AS 'EmployeeName' FROM Employees";


  SqlDataAdapter dsda=new SqlDataAdapter(strCmd,strConn);


  DataSet ds=new DataSet();


  dsda.Fill(ds,"EmployeeList");


  DataTable dt=ds.Tables["EmployeeList"];


  //第一种方法


  //DDL1是一个DropDownList控件


  DDL1.DataSource=dt.DefaultView;


  DDL1.DataTextField="EmployeeName";


  DDL1.DataValueField="employeeid";


  DDL1.DataBind();


  /*第二种方法


  dt.Columns.Add("EmployeeName",typeod(String),"lastName+','+firstName");


  DDL1.DataTextField="EmployeeName";


  DDL1.DataBind();


  * /







文章评论】 【收藏本文】 【推荐好友】 【打印本文】 【论坛讨论

   相关文章:
·给你的FileSystemObject对象加把锁 ·在 Web 页上使用条件数值格式
·连接数据库查询手册(不仅仅适用于asp) ·警惕"给你的FileSystemObject对象加把锁"
·用ASP做全文检索 ·如何把ASP编写成DLL

   文章评论:(条)
  
 请留名: 匿名评论   点击查看所有评论 网管论坛
 

  责任编辑:一分  声明:刊登此文章是为了传递更多信息,文章内容仅供参考,转载请注明出处。