一般支持数据绑定的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”); |