在网页上排序下拉列表时出错

Error when sorting a dropdownlist on webpage

我有一个网页不允许我对下拉列表进行排序。我有一个 SQLDataSource 连接配置为显示 table tblCodesWorkNotRec 中的行描述。当我转到 Order By 并选择 sort by Description,然后测试查询时,出现错误 -

The text, ntext, and image data types cannot be compared or sorted, except when using IS NULL or LIKE operator.

为什么?

如果您需要查看代码,什么代码 - aspx 或 vb?

这是 vb 代码:

Imports System
Imports System.Data
Imports System.Data.OleDb
Imports System.Data.SqlClient
Imports System.Configuration
Imports System.Web.Mvc

Partial Class TimeOffAddNoRequest
    Inherits System.Web.UI.Page


    Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load

        'Once data is edited on this webpage, do not go back to first loaded data (data from gridview)
        If Page.IsPostBack = True Then
            Return
        End If

        Dim windowsLoginName As System.String = HttpContext.Current.User.Identity.Name   'System.Security.Principal.WindowsIdentity.GetCurrent().Name

        Dim split As String() = Nothing
        Dim vname As String

        Dim sqlConnection As New SqlConnection("Data Source=janetdev;Initial Catalog=TimeSQL;Persist Security Info=True;User ID=sa;Password=password")
        Dim cmd, cmd1, cmd2 As New SqlCommand
        Dim returnValue, returnValue1, returnValue2 As Object
        Dim dt As Date
        dt = Today
        MsgBox(Today)

        'Get network login name (name only)
        split = windowsLoginName.Split("\".ToCharArray)
        vname = split(1)

        'Get firstname from tblEmployees that matches login name
        cmd.CommandText = "SELECT FirstName FROM tblEmployees where login = '" & vname & "'"
        cmd.CommandType = CommandType.Text
        cmd.Connection = sqlConnection

        'Get lastname from tblEmployees that matches login name
        cmd1.CommandText = "SELECT LastName FROM tblEmployees where login = '" & vname & "'"
        cmd1.CommandType = CommandType.Text
        cmd1.Connection = sqlConnection

        'Get employeeid from tblEmployees that matches login name 
        cmd2.CommandText = "SELECT EmployeeID FROM tblEmployees where login = '" & vname & "'"
        cmd2.CommandType = CommandType.Text
        cmd2.Connection = sqlConnection

        sqlConnection.Open()

        'firstname
        returnValue = cmd.ExecuteScalar()

        'lastname
        returnValue1 = cmd1.ExecuteScalar()

        'employeeid
        returnValue2 = cmd2.ExecuteScalar()

        sqlConnection.Close()

        'display firstname and lastname on screen
        TextBox3.Text = returnValue & " " & returnValue1
        TextBox4.Text = returnValue2

        'display today's date
        DateRequested.Text = dt

        'Get value of other fields 

        If Not [String].IsNullOrEmpty(Request.QueryString("BeginDateOff").ToString()) Then
            'Retrieving the BeginDateOff Value
            BeginDate.Text = Request.QueryString("BeginDateOff").ToString()
        End If

        If Not [String].IsNullOrEmpty(Request.QueryString("EndDateOff").ToString()) Then
            'Retrieving the EndDateOff Value
            EndDate.Text = Request.QueryString("EndDateOff").ToString()
        End If

        If Not [String].IsNullOrEmpty(Request.QueryString("BeginTimeOff").ToString()) Then
            'Retrieving the BeginTimeOff Value
            BeginTimeDD.SelectedValue = Request.QueryString("BeginTimeOff").ToString
        End If

        If Not [String].IsNullOrEmpty(Request.QueryString("EndTimeOff").ToString()) Then
            'Retrieving the EndTimeOff Value
            EndTimeDD.Text = Request.QueryString("EndTimeOff").ToString()
        End If

        'Retrieving the All Day Value
        AllDay.Checked = Boolean.Parse(Request.QueryString("AllDay_YesNo"))
        'AllDay.Checked = Request.QueryString("AllDay_YesNo")

        'Retrieving the WorkHoursNotRecordID
        wkid.Text = Request.QueryString("WorkHoursNotRecordID").ToString()

        If Request.QueryString("description").ToString = "Unknown" Then
            Label2.Text = "You must change the reason from Unknown."
            DropDownList2.Focus()
            Exit Sub
        Else
            'Retrieving the Description Value
            DropDownList2.Text = Request.QueryString("Description").ToString()
        End If

        BeginDate.Focus()

    End Sub

这是 aspx 代码:

<%@ Page Title="" Language="vb" AutoEventWireup="false" MasterPageFile="~/Site.Master" CodeBehind="TimeOffAddNoRequest.aspx.vb" Inherits="timework.TimeOffAddNoRequest" %>
<%@ Register Assembly="AjaxControlToolkit" Namespace="AjaxControlToolkit" TagPrefix="asp" %>
<asp:Content ID="Content1" ContentPlaceHolderID="HeadContent" runat="server">
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">
    <asp:ToolkitScriptManager ID="toolkitScriptManager" runat="server" />
    <asp:Label ID="Label2" runat="server" 
         style="color: #990033; font-weight: 700"></asp:Label>
    <asp:Label ID="Label1" runat="server" 
         style="color: #000099; font-weight: 700"></asp:Label>
    <br />
    <label>Employee Name:</label><asp:TextBox ID="TextBox3" runat="server" BorderStyle="None" 
         style="margin-left: 7px; font-size: medium; font-weight: 700;" 
         Width="150px" Height="22px" AutoPostBack="True"></asp:TextBox>
    <asp:TextBox ID="TextBox4" runat="server" Width="129px" 
         AutoPostBack="True" Visible="False"></asp:TextBox>
    <br />
    <hr align="left" style="width: 791px; margin-left: 0px" />
    <label>Date Requested:<asp:TextBox ID="DateRequested" runat="server" style="margin-left: 9px; font-size: medium; font-weight: 500;" 
         Width="150px" Height="22px" AutoPostBack="True" BorderStyle="None"></asp:TextBox>
    </label>
    <br />
    <br />
    &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <label>Begin Date Off:</label>
    <asp:TextBox ID="BeginDate" runat="server" style="margin-left: 10px; font-size: medium; font-weight: 500;" 
         Width="150px" Height="22px" AutoPostBack="True" BorderStyle="Solid" 
            BorderWidth="1px"></asp:TextBox>
     <label>&nbsp; End Date Off:</label>
     <asp:TextBox ID="EndDate" runat="server" style="margin-left: 15px; font-size: medium; font-weight: 500;" 
         Width="150px" Height="22px" AutoPostBack="True" BorderStyle="Solid" 
            BorderWidth="1px"></asp:TextBox>
    <br />
    <br />
    &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <label> All Day?</label>&nbsp;
    <asp:CheckBox ID="AllDay" runat="server" AutoPostBack="True" />
    <label>&nbsp;&nbsp; Begin Time Off:</label>&nbsp;<label>&nbsp;
    <asp:DropDownList ID="BeginTimeDD" runat="server" 
        DataSourceID="SqlDataSource1" DataTextField="Time" DataValueField="Time" 
        Height="26px" Width="100px">
    </asp:DropDownList>
        &nbsp; End Time Off:</label>&nbsp;<asp:DropDownList ID="EndTimeDD" 
            runat="server" DataSourceID="SqlDataSource1" DataTextField="Time" 
            DataValueField="Time" Height="26px" Width="100px">
    </asp:DropDownList>
    <br />
    <br />
    <asp:SqlDataSource ID="SqlDataSource1" runat="server" 
        ConnectionString="<%$ ConnectionStrings:TimeSQLConnectionString2 %>" 
        SelectCommand="SELECT [Time] FROM [tblCodesTime] ORDER BY [Time]">
    </asp:SqlDataSource>
       <label>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Reason:</label>  
       <asp:DropDownList 
        ID="DropDownList2" runat="server" AutoPostBack="True" 
        DataSourceID="SqlDataSource2" DataTextField="Description" 
        DataValueField="Description" Height="26px" Width="149px">
    </asp:DropDownList>
    <br />
    <asp:SqlDataSource ID="SqlDataSource2" runat="server" 
        ConnectionString="<%$ ConnectionStrings:TimeSQLConnectionString1 %>" 

        SelectCommand="SELECT [Description] FROM [tblCodesWorkNotRec] ORDER BY [Description]">
    </asp:SqlDataSource>
    <asp:TextBox ID="wkid" runat="server"></asp:TextBox>
    <br />
    <asp:Button ID="Button2" runat="server" Text="Save" />
    <br />
    <br />
 </asp:Content>

我相信你的错误是在你的 aspx 这一行

SELECT [Description] FROM [tblCodesWorkNotRec] ORDER BY [Description]

order by description 将是给您该错误的原因。您可以通过转换为 varchar:

来解决此问题
SELECT [Description] 
FROM [tblCodesWorkNotRec] 
ORDER BY Convert(varchar(max), [Description])

不过,我不确定您为什么要通过说明字段进行订购。也许最好只是取消 order by。该错误也可能发生在 order by [time] 行。但是,如果这是一个 DateTime 字段,那就没问题了。该字段可能应该重命名为不是关键字的内容,例如 CodeTime

关于您的代码的一些其他说明,重构这是个好主意。

  1. 作为建议,我会制作一个 与您的数据库对话的单个 class。不要将 sql 连接放在你的代码后面,更不要放在你的 aspx 中。 (如果您打算这样做,请选择一个位置,而不是两个位置)此 class 将拥有您所有的 sql 和 returns 只是您想要的值。

  2. 巩固你的sql。没有理由对同一个 table 进行 3 次调用以从每次调用中获取一个值。打一个电话就可以得到 3 样东西。我说的是名字、姓氏、员工 ID 电话。

  3. 不要将业务逻辑放在事件处理程序中。注意你的 Page_Load 方法。这是一个事件处理程序。您放在这里的任何代码都无法从其他地方调用,因此您最终只能一遍又一遍地复制代码。只需将调用移至它们自己的方法,然后从 Page_Load 调用该方法。 (GoF pattern - Facade)

  4. 将你的 UI 元素放在它们自己的 div 标签中并与 CSS 对齐。 去掉(或者至少仔细考虑)[​​=18=] 和 &nbsp; 标记,并使用 css 中的边距之类的东西来移动元素。同时将所有内联样式标签移动到 css.