|
0 / 0 / 0
Регистрация: 25.09.2008
Сообщений: 5
|
|
алгоритм обмена сообщениями25.09.2008, 11:43. Показов 5768. Ответов 11
Метки нет (Все метки)
Здравствуйте
Помогите в алгоритме для следующей задачи Нужно реализовать обмен сообщениями между зарегистрированными пользователями на php+mysql. Получил совет создать таблицу msg(id, from_user_id, to_user_id, text, date, parent_msg) Но я думаю это будет занимать слишком много процессорного времени и ресурсов оперативной памяти даже для того чтобы сформировать список между какими пользователями происходил диалог. Может есть способы пооптимизированнее? Заранее спасибо
0
|
|
| 25.09.2008, 11:43 | |
|
Ответы с готовыми решениями:
11
Скрипт обмена сообщениями Решение для обмена сообщениями внутри сайта Обмен личными сообщениями |
|
Гость-1000
|
|
| 25.09.2008, 14:34 | |
|
Тебе типа чата нужно? или как форум, чтобы это работало?(я имею ввиду скорость обмена сообщениями у пользователей) всё зависит от колличества пользователей, и частоты написания сообщений...
на колличествах пользователей до 100, я думаю что таблица которую тебе посоветовали будет оптимальным вариантом(можно ещё XML документ использовать, с теми же полями, он при небольшом кол-ве сообщений будет меньше чем БД кушать), по соотношению сложность/эффективность... даже если обмен сообщениям идёт на скорости чата (только надо будет чистить эту таблицу периодически, определить время хранения сообщения, чтобы она не расползалась до слишком больших значений...) |
|
|
0 / 0 / 0
Регистрация: 25.09.2008
Сообщений: 5
|
|
| 26.09.2008, 11:34 [ТС] | |
|
подскажите как запрос
"select to_user_id from msg where from_user_id=5;" сделать таким чтобы он выбирал строки с уникальным to_user_id
0
|
|
|
39 / 39 / 5
Регистрация: 06.02.2011
Сообщений: 123
|
|
| 06.02.2011, 21:19 | |
|
SELECT DISTINCT to_user_id FROM msg WHERE from_user_id=5;
это имелось в виду? А у меня вопрос есть Т. к. одно сообщение относится к 2 пользователям (у одного - исходящее, у другого - входящее), то как реализовать удаление? Добавлено через 31 минуту Все, разобралась, вопрос отменяется :-)
0
|
|
|
26 / 18 / 1
Регистрация: 05.02.2011
Сообщений: 55
|
||
| 06.02.2011, 21:28 | ||
|
Так сделали?
0
|
||
|
39 / 39 / 5
Регистрация: 06.02.2011
Сообщений: 123
|
|
| 06.02.2011, 21:44 | |
|
Ага, так! Спасибо.
Вот думаю только, наверное триггер надо написать. Только вот не знаю какой. Видимо, AFTER UPDATE, но насколько это рационально, сначала обновить запись, а потом удалить ее?
0
|
|
|
126 / 93 / 18
Регистрация: 09.01.2011
Сообщений: 467
|
||
| 07.02.2011, 00:14 | ||
|
0
|
||
|
39 / 39 / 5
Регистрация: 06.02.2011
Сообщений: 123
|
|
| 07.02.2011, 00:22 | |
|
Поэтому-то так сложно) Надо так, чтоб если один удалит сообщение, то у второго оно останется, а не пропадет
0
|
|
|
26 / 18 / 1
Регистрация: 05.02.2011
Сообщений: 55
|
||
| 07.02.2011, 04:29 | ||
|
Мне кажется этот вариант самый оптимальный, не вижу смысла создавать 2 записи на одно сообщение, пусть в варианте который я озвучил и на 1 запрос больше будет, но БД не будет так сильно разрастаться.
0
|
||
|
126 / 93 / 18
Регистрация: 09.01.2011
Сообщений: 467
|
||||
| 07.02.2011, 08:28 | ||||
|
0
|
||||
|
26 / 18 / 1
Регистрация: 05.02.2011
Сообщений: 55
|
|
| 07.02.2011, 08:52 | |
|
Ну в принципе можно так попробовать... Но не получится использовать это для нескольких получателей, объясню...
В том варианте который я предложил, выборка писем происходит скажем по полю inbox и outbox, т.е. в первом хранится id получателя, во втором отправителя, в БД соответственно созданы индексы для этих полей, выборка будет происходить мгновенно, а для нескольких получателей нужно будет хранить например так "1:2:3:4" плохой вариант, ИМХО. Да и для чего обычному юзеру потребуется отправлять массово письма?! Спамерам и администрации, имхо, письма и от тех и от других юзер сразу удаляет, если конечно он заглядывает в учетку. Вот так я это всё вижу... Добавлено через 12 минут Щас посплю и в своем блоге статью напишу про реализацию ЛС, в своем видении....
0
|
|
|
126 / 93 / 18
Регистрация: 09.01.2011
Сообщений: 467
|
|
| 07.02.2011, 16:33 | |
|
evgentus, для каких целей это должно использоваться, меня не интересует. Я просто помогаю с реализацией.
0
|
|
| 07.02.2011, 16:33 | |
|
Помогаю со студенческими работами здесь
12
Система обмена сообщениями Система обмена сообщениями Реализовать механизм обмена сообщениями. Приложение для обмена сообщениями Создание севрера обмена сообщениями Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
|
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
|
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
|
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога
Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
|
|
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование
. \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json>
Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом.
# Check if. . .
|
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так:
https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347
Основана на STM32F303RBT6.
На борту пять. . .
|
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
|
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу,
и светлой Луне.
В мире
покоя нет
и люди
не могут жить в тишине.
А жить им немного лет.
|