Your Privacy Matters: We use our own and third-party cookies to improve your experience on our website. By continuing to use the website we understand that you accept their use. Cookie Policy
165
Sort on date column in infragistics win ultrawingrid.
posted

Hi,

I am facing a problem while sorting on date column when header is clicked. The dates are sorted as string.

The following is the code i am using.

sprData.SetText(SPR_COL_DTM, idx,

 

String.Format("{0:MMM d yyyy hh:mm:ss:ffftt}", .Fields("act_dtm"

).value))

this is the code which populates the column in Ultrawingrid.

Thank you,

Basavaraj P Hiremath.

  • 616
    Suggested Answer
    posted

    If column not have data type like DateTime, the data will be sorting like string.

    • 165
      posted in reply to Valek

      How to change the data type of the column? when i try to change the property of the Ultrawin grid, its not allowing? is there any way so that i can change the property of the column at run time by coding ?

      • 469350
        Offline posted in reply to Gimhan

        It would be better to use SortComparer that simply ignores the time portion of the date than to alter the data in this way or return a date as a string.

        • 20
          posted in reply to Mike Saltzman

          Ths is happening due to the Date + Time format is bound to the coloumn. To acheive both sorting and filtering sametime you need to get the date portion out before bind it to the grid. I had the same problem and I could achive it using following code in the SQL select statement.

          CONVERT(datetime, CONVERT(CHAR(10), OrderDate, 103), 103) as OrderDate

           

          • 469350
            Offline posted in reply to basavaraj

            If the values in the column are of type DateTime, then they will be sorted as dates. There is no Date datatype in DotNet as far as I am aware.

            It sounds to me like your database is using some unusual type that the DotNet BindingManager or DataTable does not know how to handle and so it's falling back to using strings. That has nothing to do with the grid and the grid has no control over this.

            If you need to handle the sorting yourself, you could use a SortComparer on the grid column and compare the values yourself. Perhaps you can use DateTime.Parse to convert the date strings into actual dates.

            But you might be better off trying to find out why your date values are being interpreted by DotNet as string, since sorting will not be the only problem this causes. You will have problems filtering, summarizing, and dealing with the dates in a whole lot of ways if they are stored as strings.

            • 165
              posted in reply to Brian Fallon

              Hi,

              The value that is coming from database is of  "date" data type. Do i need to convert this to integer type then sort it and then again convert it back to date and then populate the grid...?

              • 616
                posted in reply to Brian Fallon

                You can set: ultraGrid.DisplayLayout.Bands[0].Columns[0].Style = Infragistics.Win.UltraWinGrid.ColumnStyle.DateTime;. But it's can't support format {0:MMM d yyyy hh:mm:ss:ffftt}