可用的约会

时间:2012-09-06 19:34:32

标签: mysql

我有两个mysql表,日程表和约会。在计划表中有定义的医生终端,而在其他预约的预约。问题是医生总是可以更改他的终端,我不能在约会表中粘贴引用,我只想在两个医生的一个mysql查询中获得可用的终端。那可能吗?

CREATE TABLE `schedule` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  `from` timestamp NULL DEFAULT NULL,
  `to` timestamp NULL DEFAULT NULL,
  `doctor_id` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=9 DEFAULT CHARSET=latin1;


INSERT INTO `schedule` (`id`, `from`, `to`, `doctor_id`)
VALUES
    (1, '2012-09-06 14:00:00', '2012-09-06 14:59:59', 1),
    (2, '2012-09-06 15:00:00', '2012-09-06 15:59:59', 1),
    (3, '2012-09-06 16:00:00', '2012-09-06 16:59:59', 1),
    (4, '2012-09-06 17:00:00', '2012-09-06 17:59:59', 1),
    (5, '2012-09-06 14:00:00', '2012-09-06 14:59:59', 2),
    (6, '2012-09-06 15:00:00', '2012-09-06 15:59:59', 2),
    (7, '2012-09-06 16:00:00', '2012-09-06 16:59:59', 2),
    (8, '2012-09-06 17:00:00', '2012-09-06 17:59:59', 2);

CREATE TABLE `appointments` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  `from` timestamp NULL DEFAULT NULL,
  `to` timestamp NULL DEFAULT NULL,
  `doctor_id` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=9 DEFAULT CHARSET=latin1;


INSERT INTO `appointments` (`id`, `from`, `to`, `doctor_id`)
VALUES
    (3, '2012-09-06 16:00:00', '2012-09-06 16:59:59', 1),
    (4, '2012-09-06 17:00:00', '2012-09-06 17:59:59', 1),
    (5, '2012-09-06 14:00:00', '2012-09-06 14:59:59', 2),
    (8, '2012-09-06 17:00:00', '2012-09-06 17:59:59', 2);

1 个答案:

答案 0 :(得分:3)

如果保证约会ID将等于schedule id,那么:

select `id`,`from`,`to`,`doctor_id`
from schedule
where `id` not in 
(select `id` from appointments)
order by `doctor_id`,`from` 

Sqlfiddle

如果无法保证约会ID被链接,那么:

select `id`,`from`,`to`,`doctor_id`
from schedule
where `id` not in 
(select `t1`.`id` 
from(
select `s`.`id`,`s`.`from`,`s`.`to`,`s`.`doctor_id` 
from schedule as s 
inner join 
appointments as a
on `s`.`doctor_id`=`a`.`doctor_id`
and `s`.`from`=`a`.`from`
and `s`.`to`=`a`.`to`)
as t1)

Sqlfiddle