Форум программистов, компьютерный форум, киберфорум
MySQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 0
Регистрация: 05.11.2012
Сообщений: 3

Проверка перед созданием сообщения

24.06.2013, 14:33. Показов 1057. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Необходимо сделать проверку перед созданием сообщения пользователю на сайте написаном на php.
И при добавлением сделать проверку на возможность создания сообщения:
1. Есть ли пользователь
2. Не находится ли создатель сообщения в игнор листе у получателя
Собственно вопрос - как это лучше сделать, одним запросом
MySQL
1
2
3
4
5
SELECT COUNT(*) ,
(SELECT COUNT(*)
FROM user_ignore_list
WHERE user_id=1 AND ignore_user_id=2) as is_ignore
FROM USER WHERE user_id=1
Либо сделать два отдельных запроса?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
24.06.2013, 14:33
Ответы с готовыми решениями:

Проверка данных в форме перед созданием записи в таблице
Здрасте. Вот пришлось делать базу но так как я в этом ламер и самоучителя по Access 2003 в моё вопросе аж никак не хватает, а желанием...

Несколько вопросов перед созданием сайта
Здравствуйте, уважаемые форумчане! Т.к. не имею опыта, но желаю обучаться, решил задать несколько вопросов. Собственно сабж: Решил...

Как проверить существование папки перед её созданием?
вообщем я создаю тест, помогите сделать проверку и создание папки, в начале код проверяет или пытается создать папку с названием...

1
363 / 334 / 38
Регистрация: 29.03.2011
Сообщений: 838
25.06.2013, 10:33
@mtttttv, если нет каких-то других условий, то:
1) Собсна зачем вам отдельная проверка - есть ли получатель, если вы уже выбираете его по id?
2) Вообще, если экономить запросы (сообщения - очень частая вещь) - все проверки можно сделать сразу в INSERT:
MySQL
1
2
3
4
5
INSERT INTO `messages` ( `text`, `sender`, `recipient`,...)
  SELECT ('$text', '$sender', '$recipient', ...) 
  FROM `user` WHERE `user_id`='$recipient' AND
   (SELECT COUNT(*) FROM `user_ignore_list` 
     WHERE `user_id`='$recipient' AND `ignore_user_id`='$sender') = 0
Тут мы проверяем, что пользователь существует, затем, что отправитель им не залочен. Пока оба условия не сработают - ничего не вставится. Мы можем узнать об этом в php, получив число записей:
PHP
1
2
3
4
$query="код запроса выше";
if ( mysql_query($query) ) { //Сообщение отправлено
} else { //Сообщение не отправлено
}
3) Но это - хак. Пока сервер справляется лучше всё разделить по отдельным простым запросам - сопровождать будет проще.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
25.06.2013, 10:33
Помогаю со студенческими работами здесь

Установка поддерживаемого расширения перед созданием установщика
здравствуйте! в общем дело такое - есть проект в Visual Studio, нужно создать установщик в Inno Setup, и при этом нужно чтобы после...

Перед созданием нового файла проверить есть ли такой файл
Добрый день. В интернете полно информации о создании файла например: ofstream ofs("test.txt"); //создать ofs.close(); ...

Как очищать DBLookupCombobox перед созданием новой записи (gdb interbase)?
Получилось связать 2 DBLookupComboboxeh ( dbgrideh - ibdatabase - ibtransaction - datasource - ibdataset). Добавляю записи в базу через...

FAQ: Что делать если выпал BSOD (обязательно читать перед созданием темы)
Если вы хотите получить помощь на форуме, обязательно выполните пункты 5 и 6. Если вы не предоставите дампы и отчет вас отправят в эту...

Поправка к "Обязательно читать перед созданием темы".
За ранее извиняюсь... Последнее время очень часто замечаю, что люди не хотят читать много текста(замечаю это именно на форумах). По этому...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru