0

<asp:SqlDataSource使用连接字符串连接到数据库,但是我希望将 2 列合并在一起以创建 1 列,例如:

Column: First Name
Column: Last Name

创建:

Column: Full Name

我很难找到如何在 aspx 中执行此操作,但很容易直接在页面中找到此操作。

我的 Sql 数据源如下:

<asp:SqlDataSource ID="databaseWork" runat="server" ConnectionString="<%$ ConnectionStrings:ConnectionString%>" SelectCommand="SELECT  [FirstName],[LastName] FROM [People]">
    </asp:SqlDataSource>

我想把它们放在一个下拉列表中。我的下拉列表是:

<asp:DropDownList ID="ddlPeople" runat="server" AutoPostBack="True" DataSourceID="databaseWork" DataTextField= 'FirstName' DataValueField="ID">
</asp:DropDownList>

无论我做什么似乎都没有用,我去了多个站点并尝试了很多东西,但是我自己发现我可以修改 SQL 查询并创建自己的列,而不是在使用它们时将字段连接在一起。

我正在为我自己的问题添加一个答案,因为我相信这对想要相同结果的其他人非常有帮助。

4

2 回答 2

0

结果证明,我所做的非常简单,可以实现 1 列同时创建了 2 列或更多列。

我的 SqlDataSource 如下:

<asp:SqlDataSource ID="databaseWork" runat="server" ConnectionString="<%$ ConnectionStrings:ConnectionString%>" SelectCommand="SELECT [FirstName] + ' ' + [LastName], AS [FullName] FROM [People]">
</asp:SqlDataSource>

现在,当将其用作下拉列表或网格视图中的列时,您可以简单地调用我们创建的新列。

下拉列表示例:

<asp:DropDownList ID="ddlPeople" runat="server" AutoPostBack="True" DataSourceID="databaseWork" DataTextField= 'FullName' DataValueField="ID">

带列的网格视图示例:

<asp:GridView
  ID="gridPeople"
  runat="server"
  DataSourceID="databaseWork"
  AllowPaging="True" 
  AllowSorting="True" 
  AutoGenerateColumns="False" PageSize="50">

    <Columns> 
        <asp:BoundField DataField="FullName" HeaderText="Full Name Column"  SortExpression="FullName" />

    </Columns>

</asp:GridView>

与其尝试在下拉列表或网格视图中动态添加两列来创建一列,不如在 SQL 查询本身中创建列并简单地调用它会更好、更容易。现在,当我们调用 FULL Name 时,我们会得到如下结果:

  1. 约翰·史密斯
  2. 汉娜蒙塔娜
于 2016-10-05T02:20:37.963 回答
0

SqlDataSource

<asp:SqlDataSource ID="databaseWork" runat="server" ConnectionString="<%$ ConnectionStrings:ConnectionString%>" SelectCommand="SELECT [ID], [FirstName] + ' '+[LastName] AS [FullName] FROM [People]">
</asp:SqlDataSource>

备注查询"SELECT [ID], [FirstName]+' '+[LastName] AS [FullName] FROM [People]"

对于下拉

<asp:DropDownList ID="ddlPeople" runat="server" AutoPostBack="True" DataSourceID="databaseWork" DataTextField= 'FullName' DataValueField="ID">
于 2016-10-05T03:35:34.190 回答