vitfix Posted November 22, 2015 Share Posted November 22, 2015 Здравствуйте.Подскажите в чём причина.При переносе сообщений из одной темы в другую, они смещают уже имеющиеся сообщения и становятся первыми. Link to comment Share on other sites More sharing options...
siv1987 Posted November 22, 2015 Share Posted November 22, 2015 При переносе сообщений из одной темы в другую, они смещают уже имеющиеся сообщения и становятся первыми.Потому что сообщения в теме сортируются по определенным критериям, по умолчанию по ид. Соответственно они будут сдвигать вниз существующие сообщения, в порядке следования ид. Link to comment Share on other sites More sharing options...
vitfix Posted November 23, 2015 Author Share Posted November 23, 2015 Потому что сообщения в теме сортируются по определенным критериям, по умолчанию по ид. Соответственно они будут сдвигать вниз существующие сообщения, в порядке следования ид.Так что интересно, это происходит не всегда... Link to comment Share on other sites More sharing options...
siv1987 Posted November 23, 2015 Share Posted November 23, 2015 Не всегда. Перечетайте внимательно цитируемое вами сообщение, там написано почему они сдвигаются и почему это происходит не всегда. Если обьяснять на пальцах, то сообщения в теме имеют определенную хронологию. Условно возьмем ид - 1, 3, 6, 8. А теперь представьте что переносите сообщение из другой темы с ид 5. Согласно сортировки она будет третьей в теме - 1, 3, 5, n. Link to comment Share on other sites More sharing options...
vitfix Posted November 23, 2015 Author Share Posted November 23, 2015 А можно это как-то в ручную исправить? Link to comment Share on other sites More sharing options...
kgb Posted November 23, 2015 Share Posted November 23, 2015 Потому что сообщения в теме сортируются по определенным критериям, по умолчанию по ид. Разве? А не по дате? Отсюда, если дата переносимого сообщения ранее уже имеющихся, то оно и буде впереди Link to comment Share on other sites More sharing options...
siv1987 Posted November 23, 2015 Share Posted November 23, 2015 Можно. Но на практике много геморроя ввиду того, что сортировка происходит по первичному ключу. Чтобы его сменить нужно обновить ид сообщение на текущее значение AUTO_INCREMENT* в таблице. Потом обновить AUTO_INCREMENT + 1. После перестроить темы и форумы в АЦ. А еще есть кучу внешних связей которые нужно обновить - прикрепленные аттачи сообщения, репутация, и бог весть знает что еще ссылается на этот идентификатор.Как видно задача не самая простая, и если для вас незнакомо такое понятие как первичный ключ (PRIMARY KEY) то его лучше не трогать.Другой вариант сортировать сообщения по дате их создания. Тогда манипулировать сообщениями в теме можно изменив только дату сообщения, что намного проще. *Теоретически можно обновить и на MAX(ид)+1, но максимальный ид не всегда соответствует автоинкременту таблицу, например были удалены последние 10 сообщения. В таком случае могут быть коллизии, когда одно сообщение удаленно, вместо нее появляется другое с этим ид, а где-то есть старая связь. Тогда нарушается логическая целостность. 1 Link to comment Share on other sites More sharing options...
siv1987 Posted November 23, 2015 Share Posted November 23, 2015 Разве? А не по дате?По умолчанию по ид. До 3.4 тип сортировки можно было настроить в АЦ. После 3.4 настройка была выпилена из АЦ, и управлять ею можно только из конфигурационного файла. Link to comment Share on other sites More sharing options...
Alien2001 Posted November 24, 2015 Share Posted November 24, 2015 По умолчанию по ид. До 3.4 тип сортировки можно было настроить в АЦ. После 3.4 настройка была выпилена из АЦ, и управлять ею можно только из конфигурационного файла. Уже в 3.3 этого в админке нет. Мне пришлось через конфигурацию прописывать:INFO['post_order_column'] = 'post_date'; // Other valid values: 'pid' Я не могу понять, как у ТС получилось, что сообщения сдвигаются. Ведь при обычном порядке вещей ID и дата напрямую связаны - ID присваиваются по порядку создания, соответственно, чем позже сообщение создано, тем больше ID. У меня на форуме такое возможно, но только потому, что он когда-то был сконвертирован из совершенно другого движка, и конвертация с присвоением ID шла не по дате, а по темам и конференциям. Потому мне и пришлось менять сортировку. Link to comment Share on other sites More sharing options...
siv1987 Posted November 24, 2015 Share Posted November 24, 2015 Я не могу понять, как у ТС получилось, что сообщения сдвигаются. Ведь при обычном порядке вещей ID и дата напрямую связаны - ID присваиваются по порядку создания, соответственно, чем позже сообщение создано, тем больше ID.Посмотрите на пример выше, ведь ТС мог перенести сообщения с ид созданные как после этой темы так и до. Если перенести ранние сообщения, созданные до, то они непременно окажутся впереди существующих. Чтобы они оказались в конце, дата сообщения должно быть больше чем дата последнего поста в теме, соответственно и ид будет больше. У меня на форуме такое возможно, но только потому, что он когда-то был сконвертирован из совершенно другого движка, и конвертация с присвоением ID шла не по дате, а по темам и конференциямИд присваивается не по дате. При конвертации либо сохраняются старые ид, либо выдаются новые автоинкрементом где сообщения сортируются по ид чтобы сохранить последовательность при получении нового. Отсюда два вариант, либо это не произошло, хотя в конвертере сортировка есть, либо на старом форуме произвольно меняли дату и сортировали сообщения по ней. Или вы не правильно поняли логику при переносе сообщений в другую тему. То что описывает ТС возможно на любом форуме, об этом наглядно можно посмотреть по приведенному примеру. Все зависит когда были созданы эти сообщений, до или после. Link to comment Share on other sites More sharing options...
Alien2001 Posted November 24, 2015 Share Posted November 24, 2015 Если перенести ранние сообщения, созданные до, то они непременно окажутся впереди существующих. Чтобы они оказались в конце, дата сообщения должно быть больше чем дата последнего поста в теме, соответственно и ид будет больше. Кажется, догнал. Конечно, если перенести более ранние сообщения, то они окажутся до - а какие тут могут быть варианты - у них и дата, и ID будут меньше. А других параметров для сортировки больше нет. Я почему-то решил, что ТС более поздние сообщения имеют меньший ID и оказываются, соответственно, до. Link to comment Share on other sites More sharing options...
Recommended Posts
Create an account or sign in to comment
You need to be a member in order to leave a comment
Create an account
Sign up for a new account in our community. It's easy!
Register a new accountSign in
Already have an account? Sign in here.
Sign In Now