-
> 002 и 2 -это должно быть одно и тоже, а 2 после 002 потому,
> что она и в начальном наборе идет тоже после
Если это одно и то же, то их порядок зависи от алгоритма сортировки, т.к. некоторые алгоритмы могут переставлять в итоговом множестве равные значения.
-
-
> Erick (02.07.08 15:51) [14]
Алгоритмы сортировки абстрактны, им по барабану что сортировать - хоть строки, хоть черта лысого. За работу с конкретными типами сортируемых этими алгоритмами данных отвечают другие алгоритмы - алгоритмы сравнения. Вот там как раз и важно содержимое твоих строк. Но о сравнении пока речь не идет - ты еще не определился с алгоритмом сортировки.
-
> TStringList.CustomSort
> Туда подсовываешь свою функцию, которая для 2х значений
> скажет, какое больше. Собственно, я уже повторяюсь [3]
Если к примеру я отсортирую в нужном порядке данное поле, то как сделать, то как сделать чтобы весь набор отсортировался? Т.е. если я значения этого поля пишу в TStringList или еще куда-то, потом сортирую, как мне как сохранить соответвствие между сзначениями этого и других полей?
-
> Алгоритмы сортировки абстрактны, им по барабану что сортировать
> - хоть строки, хоть черта лысого. За работу с конкретными
> типами сортируемых этими алгоритмами данных отвечают другие
> алгоритмы - алгоритмы сравнения. Вот там как раз и важно
> содержимое твоих строк. Но о сравнении пока речь не идет
> - ты еще не определился с алгоритмом сортировки.
Да хоть "пузырьком", как разница какой алгоритм использовать. Мне нужно отсортировать по возрастанию номера помещений, которые храняться в текстовом поле.
-
> как мне как сохранить соответвствие между сзначениями этого
> и других полей?
Номера помещений у тебя уникальны? Если да, то соответствие уже есть. А если нет, то не имеет значения, какое из них первое, какое - второе. Главное, чтобы строки в результирующем CDS не повторялись.
Это, я думаю, ты сообразишь.
-
> Да хоть "пузырьком"
TStringList, если ты за него взялся, реализует QuickSort.
Тебе остается реализовать алгоритм сравнения.
-
> Erick (02.07.2008 16:27:23) [23]
А что ИД нет?
-
Привести нативные значения полей к единому шаблону (формату) - строке
Например шаблон NNNNNNLLLL, где
N - цифра и L - буква
Тогда получим такую картину
Нативные значения Шаблон
0001 000001____
1 000001____
234 000234____
25ПРСТ 000025ПРСТ
78А 000078А___
Б45 999999Б45_
По шаблону и сортировать
Как получить шаблон - дело "техники". Можно в запросе (если сиквель позволяет), можно через доп.поле датасета (TClientDataSet)
-
> Привести нативные значения полей к единому шаблону (формату)
> - строке
Это если оно получится. А то появится какое-нибудь "ПомеЩение 1Б2" - и тогда шаблон резко менять надо. А судя по постановке, данные не формализованы, юзеры долбят, что хотят.
-
В FB у меня нечто схожее реализовано с помощью UDF. Тригер срабатывает на добавление - изменение записи и в дополнительное поле вносит преобразованое шаблонированое значение, которое преобразуется в UDF
-
> Как получить шаблон - дело "техники". Можно в запросе (если
> сиквель позволяет), можно через доп.поле датасета (TClientDataSet)
О каком сиквеле идет речь?
-
приведи строковое к числовому и по нему отсортируй
типа select id, cast(id as integer) FROM table order by 2
-
> Виталий Панасенко(дом) (02.07.08 21:23) [32]
> приведи строковое к числовому и по нему отсортируйтипа select
> id, cast(id as integer) FROM table order by 2
опять недосмотрел... (c) Виталий Панасенко(дом)
-
>О каком сиквеле идет речь?
О диалекте SQL. Не все они позволяют разобрать строку или проверить содержит ли она только цифры
-
>Desdechado © (02.07.08 17:18) [29]
>А то появится какое-нибудь "ПомеЩение 1Б2" - и тогда шаблон резко менять надо.
Ничего не надо менять. Если буквенная часть натива слишком широка, то будут использованы только первые символы. Ну и, конечно, сам шаблон изначально должен быть достаточно "широким" чтобы вместить все значения. Например его длина должна составлять две длины нативного поля - тогда все "влезет"
-
> Ничего не надо менять.
Ой, не кажи "гоп".
А если туда вколотят с дефисами/слэшами/пробелами и прочими знаками препинания, это ж какая маска нужна....
-
> Desdechado (03.07.2008 10:47:36) [36]
Это попытка удаления гланд через заднее отверстие.
-
>Desdechado © (03.07.08 10:47) [36]
Какую ты "маску" придумал ? Сравниваются строки и только
-
> Какую ты "маску" придумал ?
Это ты придумал шаблон, а я всего лишь синоним к слову употребил...