Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
PHP 5. На примерах. Авторы: Кузнецов М.В., Симдянов И.В., Голышев С.В. PHP 5/6. В подлиннике. Авторы: Кузнецов М.В., Симдянов И.В. PHP на примерах (2 издание). Авторы: Кузнецов М.В., Симдянов И.В. PHP. Практика создания Web-сайтов (второе издание). Авторы: Кузнецов М.В., Симдянов И.В. Объектно-ориентированное программирование на PHP. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум MySQL

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: Запрос с использованием JOIN
 
 автор: mefodiy   (06.11.2008 в 14:53)   письмо автору
 
 

Помогите новичку.
Есть две таблицы с общим идентификатором "TabNo" (табельный номер).
В первой таблице “Personal” список работников (как уволенных, так и работающих), а во второй “Grafik” - табель работников по месяцам (только те, кто имел отклонения от стандртного количества рабочих дней).
В результате запроса нужно получить таблицу со списком всех работников, проработавщих хоть один день в заданном месяце (в примере 9-й месяц 2008 г) с табельным номером и числом проработанных дней. Те, кого нет в таблице “Grafik”, в итоговой таблице должны иметь число проработанных дней, равное константе (числу рабочих дней месяца), а те кто есть - число дней из таблицы “Grafik”.
Делаю такой запрос (пока без константы)

SELECT p.TabNo,g.RabDni
FROM Personal p
LEFT JOIN Grafik g USING(TabNo)
WHERE ((p.InDate<='2008-09-30' AND p.Uvolen='N') OR
(p.Uvolen='Y' AND p.OutDate>='2008-09-01')) AND
g.Year=2008 AND g.Month=9
ORDER BY TabNo;

Получаю только тех, кто есть только в таблице “Grafik”.
Несколько изменил запрос:

SELECT p.TabNo,g.RabDni
FROM Personal p
LEFT JOIN Grafik g USING(TabNo)
WHERE ((p.InDate<='2008-09-30' AND p.Uvolen='N') OR
(p.Uvolen='Y' AND p.OutDate>='2008-09-01')) AND
((g.Year=2008 AND g.Month=9) OR (g.TabNo IS NULL))
ORDER BY TabNo;

Список больше, но все равно не весь.
Прошу помочь.
Заранее благодарен.

  Ответить  
 
 автор: Gust   (12.11.2008 в 15:11)   письмо автору
 
   для: mefodiy   (06.11.2008 в 14:53)
 

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

SELECT p.TabNo,if(isnull(g.RabDni),$constanta,g.RabDni)
FROM Personal as p LEFT JOIN Grafik as  g  ON p.TabNo=g.TabNo
WHERE p.Uvolen='Y' AND ((g.Year=2008 AND g.Month=9) OR isnull(g.TabNo))
ORDER BY TabNo;

  Ответить  
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования