Правила     Закладки     Карма    Календарь    Журналы    Помощь    Поиск    PDA    Чат   
        СМС-ки
   
Пейджер выключен!
 
Фильтр авторов:    показать 
  скрыть
  Ответ в темуСоздание новой темыСоздание опроса

> Натуральная сортировка в MySQL., какой выход?
GET  
 ۩  Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



TERRAFORMING ENGINEER
******

Профиль
Журнал
Группа: ★ЛжеЭксперт★
Завсегдатай форума
Сообщений: 3900
Пользователь №: 21196
На форуме: 15 лет, 16 дней
Карма: 88




Привет, так решил написать размышления по поводу, может у кого есть что добавить.

У меня на сайте есть место где - нужно выводить отсортированные списки, много списков, хранятся они в БД в varchar`ах. Некоторые из них могут начинаться с цифр, типа такого (но там же есть строки и без цифр):

Начальный уровень
1 уровень
2 уровень
...
10 уровень
Последний уровень

Если сделать такой список ORDER BY `name` то он выведет:

1 уровень
10 уровень
2 уровень
...
Что не есть хорошо конечно, но существуют варианты:

Например, можно ввести доп. столбец с порядком вывода, но если списки могут дополнятся придется сдвигать и постоянно их пересортировывать.

Еще varchar поле представляют, как числовое типа:
ORDER BY `name`+0, чтоб отсоритровать как бы цифры, но это тоже не выход т.к. неправильно отобразит похожие строчки.

Или
ORDER BY LENGTH(name), name;//добавляют длинну значения поля

Или
ORDER BY RIGHT(CONCAT('00',number),3);

Но все же это все через Ж.
Либо некорректные результаты, либо неприемлемо долго.

Короче, пришел к выводу (особенно элементов не так много) спасет natcasesort - сортировка ручками на уровне php.


--------------------
Не тот велик, кто не падал, а тот кто падал и поднимался.
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
Placido  
Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Наблюдаю
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 1244
Пользователь №: 29445
На форуме: 13 лет, 6 месяцев, 16 дней
Карма: 144




Создать отдельную таблицу с полями id уровня, name уровня. В таблице со списками вместо "10 уровень" писать только его id.
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
sergeiss  
Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Сидел он, дум великих полон - и вдаль глядел
******

Профиль
Группа: Эксперт
Группа переписки
Сообщений: 15860
Пользователь №: 4190
На форуме: 17 лет, 1 месяц, 13 дней
Карма: 490




Вобщем, следи за логикой... Не так и сложно это сделать. Надо только проявить смекалку :) И - рекомендую - выполни по очереди все запросы, что я написал. Тогда будет понятнее, как работает финальный запрос.

Итак, шаг 1. Получить сортировку по "натуральному" виду. Используем приведение строки к числу, после чего сравниваем.
select * from `tab1`
order by cast(nam as unsigned) asc

Получаем: сначала идут все строки, которые начинаются не на число, а затем - числовые, отсортированные как нам нужно.

Немного думаем и переходим к шагу 2.
select * from `tab1`
where cast(nam as unsigned) > 0
order by cast(nam as unsigned) asc


Выбираем все строки, которые начинаются на числа.

Логично получаем шаг 3: выбор всех "нечисловых" строк
select * from tab1
where cast(nam as unsigned) = 0
order by nam


А затем берём всё и собираем в кучу посредством UNION:
select * from
(
SELECT * FROM `tab1`
where cast(nam as unsigned) > 0
order by cast(nam as unsigned) asc
) ini_1
union
select
* from
(
select * from tab1
where cast(nam as unsigned) = 0
order by nam
) ini_2



Всё, результат получен :) И не надо ПХП мучать для того, что может выполнить Мускуль. Пусть он сам работает!!!

Если требуется что-то более сложное... Ну, думай дальше сам. Трамплин для прыжка у тебя есть.


--------------------
* Хэлп по PHP
* Описалово по JavaScript
* Хэлп и СУБД для PostgreSQL

* Обучаю PHP, JS, вёрстке. Интерактивно и качественно. За разумные деньги.

* "накапливаю умение телепатии" (С) и "гуглю за ваш счет" (С)

user posted image
PMICQ
    1   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
inpost  
Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Помагите Здесь живу!!!
******

Профиль
Группа: Эксперт
Группа переписки
Сообщений: 23010
Пользователь №: 20039
На форуме: 15 лет, 3 месяца, 12 дней
Карма: 623




Переведи в int и всё.


--------------------
Обучаю веб-программированию качественно и не дорого: http://school-php.com
Фрилансер, принимаю заказы: PHP, JS, AS (видео-чаты). Писать в ЛС (Личные сообщения на phpforum).
PMПисьмо на e-mail пользователюICQ
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
GET  
 ۩  Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



TERRAFORMING ENGINEER
******

Профиль
Журнал
Группа: ★ЛжеЭксперт★
Завсегдатай форума
Сообщений: 3900
Пользователь №: 21196
На форуме: 15 лет, 16 дней
Карма: 88




sergeiss
Задумку понял, спасибо, отпишусь, как попробую. Правда неясен вопрос а если будут строки, а они есть, у которых цифра в конце или серидине, например названия книг:

1 среди первых
2x2
Аврора
Бродяги севера
Телефон 911
В августе 44-го

Тогда слова начищающиеся на букву, но имеющие цифру отсортируются неправильно.





--------------------
Не тот велик, кто не падал, а тот кто падал и поднимался.
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
bestxp  
Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



орангутанг
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 2120
Пользователь №: 36605
На форуме: 12 лет, 1 месяц, 3 дня
Карма: 115




вообще-то выдуманная проблема, сортирует он строки, а не цифры, следовательно

1
10
101 Далматинец
2
3
31
33 коровы

притом даже еще веселее

1
10
Edit Piaf
Joe Dassin
Несчастный Случай

и тд

PMПисьмо на e-mail пользователюСайт пользователяICQ
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
sergeiss  
Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Сидел он, дум великих полон - и вдаль глядел
******

Профиль
Группа: Эксперт
Группа переписки
Сообщений: 15860
Пользователь №: 4190
На форуме: 17 лет, 1 месяц, 13 дней
Карма: 490




bestxp, а в чем "выдуманность" проблемы? ТС хочет, чтобы была определенная сортировка smile.gif Я ему показал, как это можно достичь.
Ты же написал, что получим при простой сортировке по текстовому полю. И к чему это написал?


--------------------
* Хэлп по PHP
* Описалово по JavaScript
* Хэлп и СУБД для PostgreSQL

* Обучаю PHP, JS, вёрстке. Интерактивно и качественно. За разумные деньги.

* "накапливаю умение телепатии" (С) и "гуглю за ваш счет" (С)

user posted image
PMICQ
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
GET  
 ۩  Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



TERRAFORMING ENGINEER
******

Профиль
Журнал
Группа: ★ЛжеЭксперт★
Завсегдатай форума
Сообщений: 3900
Пользователь №: 21196
На форуме: 15 лет, 16 дней
Карма: 88




sergeiss
как я уже написал тебе выше способ не работает для слов с цифрами в середине или конце


--------------------
Не тот велик, кто не падал, а тот кто падал и поднимался.
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
sergeiss  
Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Сидел он, дум великих полон - и вдаль глядел
******

Профиль
Группа: Эксперт
Группа переписки
Сообщений: 15860
Пользователь №: 4190
На форуме: 17 лет, 1 месяц, 13 дней
Карма: 490




Тогда у тебя только один вариант: завести отдельное "сортировочное" поле, по которому сортировать. И заполнять его вручную.
Например, для строки "В августе 44-го" в этом сортировочном поле напиши 44.

Автоматизировать тут вряд ли что-то получится. Не, ну можно перед записью выбирать из поля только цифры и вводить их в "сортировочное" поле. Но я почти уверен, что ты получишь результат, который не ожидаешь.


--------------------
* Хэлп по PHP
* Описалово по JavaScript
* Хэлп и СУБД для PostgreSQL

* Обучаю PHP, JS, вёрстке. Интерактивно и качественно. За разумные деньги.

* "накапливаю умение телепатии" (С) и "гуглю за ваш счет" (С)

user posted image
PMICQ
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
GET  
 ۩  Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



TERRAFORMING ENGINEER
******

Профиль
Журнал
Группа: ★ЛжеЭксперт★
Завсегдатай форума
Сообщений: 3900
Пользователь №: 21196
На форуме: 15 лет, 16 дней
Карма: 88




всем спасибо решил кое что перекроить чтоб выделять поля у которых нужна сортировка


--------------------
Не тот велик, кто не падал, а тот кто падал и поднимался.
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
  Быстрый ответ
Информация о Госте
Введите Ваше имя
Кнопки кодов
Для вставки цитаты, выделите нужный текст и
НАЖМИТЕ СЮДА
Введите сообщение
Смайлики
:huh:  :o  ;) 
:P  :D  :lol: 
B)  :rolleyes:  <_< 
:)  :angry:  :( 
:unsure:  :blink:  :ph34r: 
     
Показать всё

Опции сообщения  Включить смайлики?
 Включить подпись?
 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:

Опции темы Ответ в темуСоздание новой темыСоздание опроса