假设我想在表中存储一个间隔,其中间隔可以指定为单个日期或范围,因此,字段将是:
| id | since | until | at_date |
现在,我希望情况像since is null and until is not null
或since is not null and until is null
永远不会发生,但两者since is null and until is null
都since is not null and until is not null
很好(如果指定了第一个就很好at_date
)。
也许“合并”until
并since
进入一列是有意义的,但在我的情况下,有时只选择一个或另一个是有意义的,所以我认为将它们分开是可以的。
编辑:
create table menu_availability
(menu_id int not null,
daily_serving_start time null,
daily_serving_end time null,
weekly_service_off tinyint null,
one_time_service_off date null,
constraint ch_valid_week_day
check ((weekly_service_off is null)
or (weekly_service_off <= 6 and weekly_service_off >= 0)),
constraint ch_non_empty_schedule
check ((daily_serving_start is not null and daily_serving_end is not null)
or (daily_serving_start is null and daily_serving_end is null)),
constraint ch_either_week_or_time_set
check (daily_serving_start is not null
or weekly_service_off is not null
or one_time_service_off is not null),
constraint ch_only_week_or_one_time
check ((weekly_service_off is null and one_time_service_off is not null)
or (weekly_service_off is not null and one_time_service_off is null)))
这是我到目前为止所拥有的......但它真的很乱......