首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何管理MySQL数据库表中用户的可用性

如何管理MySQL数据库表中用户的可用性
EN

Stack Overflow用户
提问于 2021-06-30 08:01:22
回答 1查看 86关注 0票数 0

我正在尝试做一个数据库设计,我有一个导师,可以通过两种方式来设置他的可用性:

  1. 通用产品一周内上市。这基本上告诉我,通常我可以在这几天的这段时间里任教。例如,周一下午4点至8点,周二上午10点至下午1点,
  2. 的具体可用性。这告诉我,在这一天,我将不能在一般可用时间,而是在这些时间。我在6月28日星期一下午2点到5点有空。如果存在日期的特定可用性,则不会显示通用可用性。

如何设计表以保存这些可用性信息?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-06-30 08:53:48

例如,如果您的数据库支持Time类型,则为伪代码。

代码语言:javascript
复制
GeneralAvailability (
    TutorId int not null,
    DayOfWeek int not null, /* 1 .. 7*/
    TimeFrom Time not null,
    TimeTo Time  not null
) 

SpecialAvailability (
    TutorId  int not null,
    AvailDate Date not null, 
    TimeFrom Time not null,
    TimeTo Time  not null
) 

或广义的

代码语言:javascript
复制
Availability (
    TutorId int  not null,
    DayOfWeek int, /* 1 .. 7, null */ 
    AvailDate Date, 
    TimeFrom Time  not null,
    TimeTo Time  not null,
    CHECK ((DayOfWeek IS NULL OR AvailDate IS NULL) AND (DayOfWeek IS NOT NULL OR AvailDate IS NOT NULL))
) 
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68190715

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档