Конференция "Базы" » Сортировка строкового поля как числового(D10/FoxPro/ADO) [dBase, FoxPro]
 
  • Desdechado © (02.07.08 16:14) [20]

    > 002 и 2 -это должно быть одно и тоже, а 2 после 002 потому,
    >  что она и в начальном наборе идет тоже после

    Если это одно и то же, то их порядок зависи от алгоритма сортировки, т.к. некоторые алгоритмы могут переставлять в итоговом множестве равные значения.
  • Johnmen © (02.07.08 16:17) [21]
    Насчет хреновости согласен
    http://sql.ru/forum/actualthread.aspx?tid=571982


    > Я же написал, что извращаться не хочется.

    Ну я уже догадался, что писать программу ты не хочешь :))
  • Сергей М. © (02.07.08 16:21) [22]

    > Erick   (02.07.08 15:51) [14]


    Алгоритмы сортировки абстрактны, им по барабану что сортировать - хоть строки, хоть черта лысого. За работу с конкретными типами сортируемых этими алгоритмами данных отвечают другие алгоритмы - алгоритмы сравнения. Вот там как раз и важно содержимое твоих строк. Но о сравнении пока речь не идет - ты еще не определился с алгоритмом сортировки.
  • Erick (02.07.08 16:27) [23]

    > TStringList.CustomSort
    > Туда подсовываешь свою функцию, которая для 2х значений
    > скажет, какое больше. Собственно, я уже повторяюсь [3]

    Если к примеру я отсортирую в нужном порядке данное поле, то как сделать, то как сделать чтобы весь набор отсортировался? Т.е. если я значения этого поля пишу в TStringList или еще куда-то, потом сортирую, как мне как сохранить соответвствие между сзначениями этого и других полей?
  • Erick (02.07.08 16:30) [24]

    > Алгоритмы сортировки абстрактны, им по барабану что сортировать
    > - хоть строки, хоть черта лысого. За работу с конкретными
    > типами сортируемых этими алгоритмами данных отвечают другие
    > алгоритмы - алгоритмы сравнения. Вот там как раз и важно
    > содержимое твоих строк. Но о сравнении пока речь не идет
    > - ты еще не определился с алгоритмом сортировки.

    Да хоть "пузырьком", как разница какой алгоритм использовать. Мне нужно отсортировать по возрастанию номера помещений, которые храняться в текстовом поле.
  • Desdechado © (02.07.08 16:36) [25]

    > как мне как сохранить соответвствие между сзначениями этого
    > и других полей?

    Номера помещений у тебя уникальны? Если да, то соответствие уже есть. А если нет, то не имеет значения, какое из них первое, какое - второе. Главное, чтобы строки в результирующем CDS не повторялись.
    Это, я думаю, ты сообразишь.
  • Сергей М. © (02.07.08 16:39) [26]

    > Да хоть "пузырьком"


    TStringList, если ты за него взялся, реализует QuickSort.

    Тебе остается реализовать алгоритм сравнения.
  • Anatoly Podgoretsky © (02.07.08 16:43) [27]
    > Erick  (02.07.2008 16:27:23)  [23]

    А что ИД нет?
  • MsGuns © (02.07.08 16:56) [28]
    Привести нативные значения полей к единому шаблону (формату) - строке
    Например шаблон NNNNNNLLLL, где
     N - цифра и L - буква

    Тогда получим такую картину

    Нативные значения    Шаблон
     0001                        000001____
     1                              000001____
     234                          000234____
     25ПРСТ                   000025ПРСТ
     78А                          000078А___
     Б45                          999999Б45_

    По шаблону и сортировать

    Как получить шаблон - дело "техники". Можно в запросе (если сиквель позволяет), можно через доп.поле датасета (TClientDataSet)
  • Desdechado © (02.07.08 17:18) [29]

    > Привести нативные значения полей к единому шаблону (формату)
    > - строке

    Это если оно получится. А то появится какое-нибудь "ПомеЩение 1Б2" - и тогда шаблон резко менять надо. А судя по постановке, данные не формализованы, юзеры долбят, что хотят.
  • zorik © (02.07.08 17:51) [30]
    В FB у меня нечто схожее реализовано с помощью UDF. Тригер срабатывает на добавление - изменение записи и в дополнительное поле вносит преобразованое шаблонированое значение, которое преобразуется в UDF
  • Anatoly Podgoretsky © (02.07.08 18:38) [31]

    > Как получить шаблон - дело "техники". Можно в запросе (если
    > сиквель позволяет), можно через доп.поле датасета (TClientDataSet)

    О каком сиквеле идет речь?
  • Виталий Панасенко(дом) (02.07.08 21:23) [32]
    приведи строковое к числовому и по нему отсортируй
    типа select  id, cast(id as integer) FROM table order by 2
  • Johnmen © (02.07.08 21:26) [33]

    > Виталий Панасенко(дом)   (02.07.08 21:23) [32]
    > приведи строковое к числовому и по нему отсортируйтипа select
    >  id, cast(id as integer) FROM table order by 2


    опять недосмотрел... (c) Виталий Панасенко(дом)
  • MsGuns © (02.07.08 22:39) [34]
    >О каком сиквеле идет речь?

    О диалекте SQL. Не все они позволяют разобрать строку или проверить содержит ли она только цифры
  • MsGuns © (03.07.08 10:05) [35]
    >Desdechado ©   (02.07.08 17:18) [29]
    >А то появится какое-нибудь "ПомеЩение 1Б2" - и тогда шаблон резко менять надо.

    Ничего не надо менять. Если буквенная часть натива слишком широка, то будут использованы только первые символы. Ну и, конечно, сам шаблон изначально должен быть достаточно "широким" чтобы вместить все значения. Например его длина должна составлять две длины нативного поля - тогда все "влезет"
  • Desdechado © (03.07.08 10:47) [36]

    > Ничего не надо менять.

    Ой, не кажи "гоп".
    А если туда вколотят с дефисами/слэшами/пробелами и прочими знаками препинания, это ж какая маска нужна....
  • Anatoly Podgoretsky © (03.07.08 12:13) [37]
    > Desdechado  (03.07.2008 10:47:36)  [36]

    Это попытка удаления гланд через заднее отверстие.
  • MsGuns © (03.07.08 14:25) [38]
    >Desdechado ©   (03.07.08 10:47) [36]

    Какую ты "маску" придумал ? Сравниваются строки и только
  • Desdechado © (03.07.08 15:19) [39]

    > Какую ты "маску" придумал ?

    Это ты придумал шаблон, а я всего лишь синоним к слову употребил...
 
Конференция "Базы" » Сортировка строкового поля как числового(D10/FoxPro/ADO) [dBase, FoxPro]
Есть новые Нет новых   [134470   +16][b:0][p:0.001]