关于时间段 存到数据库的问题-问答-阿里云开发者社区-阿里云

开发者社区> a123456678> 正文

关于时间段 存到数据库的问题

2016-06-29 13:59:04 1885 1

我们在练习开放微信公共平台的应用
我们准备是将课程表(html格式 课程表用table排版的)从学校服务器拿回来之后
通过PHP的split等函数对获取回来的课表的字符串进行操作
将每一节课的信息 提取出来保存到数据库中
根据用户不同的周数要求 用PHP 重新排版一个课程表出来(只显示某一周的课程 学校原来的课程表是整一个学期的课程都在一张表里的) 将新的课程表的url 返回给微信用户

我负责数据库建表 我准备建3个表
表一 微信ID 学号 教务密码(用作以后再次向校方服务器请求课表用)
表二 微信ID 周数 课程名
表三 微信ID 课程名 上课星期 上课节数 上课地点 上课老师
(对表二和表三 通过SQL查询 得出对应某一周的课程表)
这里就有个问题了 因为原来的课程的周数是1-8周这样的表示方式
我应该怎样才能
1.在数据库里只用一行的表示出来呢
2.还得能做到对表二和表三(查询的时候还得是只查单周的 这样才能提取出仅仅是某一周的课程数据) 通过SQL查询 得出对应某一周的课程表的效果

感觉这个问题无解 有也是很麻烦的解法
我应该乖乖的每一周做一条记录吗 感觉这样数据库会很冗余呀

取消 提交回答
全部回答(1)
  • a123456678
    2019-07-17 19:49:04

    表1 微信ID 学号 密码(用md5或者sha1加密)
    表2 微信ID 课程ID
    表3 课程ID 上课时间 课程名 上课节数 上课地点 上课老师

    表1和表2以微信ID为外键连接
    表2和表3以课程ID为外键连接
    表1就是记录人的信息,表3是记录课程的信息,人和课程是多对多的关系,所以这里表2相当于是张连接表
    表3存上课时间的好处就是,时间戳和周数应该是可以直接转的,所以在sql查询的时候其实就是7天范围的一个查找,还可以按照时间排序(因为你输出课程表肯定得要顺序的吧)然后几乎没有冗余数据
    如果表3中,同一课程一周出现多次,课程名,上课地点,上课老师可能还是重复的,可以考虑再拆一张表。(不过如果不是学校作业我觉得就不用拆了...)

    0 0
相关问答

17

回答

【大咖问答】对话PostgreSQL 中国社区发起人之一,阿里云数据库高级专家 德哥

阿里ACE 彭飞 2019-07-10 09:36:10 964462浏览量 回答数 17

162

回答

惊喜翻倍:免费ECS+免费环境配置~!(ECS免费体验6个月活动3月31日结束)

豆妹 2014-10-29 17:52:21 222953浏览量 回答数 162

145

回答

【新手入门】云服务器linux使用手册

fanyue88888 2012-11-26 17:14:18 157055浏览量 回答数 145

8

回答

OceanBase 使用动画(持续更新)

mq4096 2019-02-20 17:16:36 333819浏览量 回答数 8

110

回答

OSS存储服务-客户端工具

newegg11 2012-05-17 15:37:18 292250浏览量 回答数 110

33

回答

Win Server 2003-2016 加密勒索事件必打补丁合集

妙正灰 2017-05-15 10:44:38 277482浏览量 回答数 33

38

回答

安全组详解,新手必看教程

我的中国 2017-11-30 15:23:46 256846浏览量 回答数 38

21

回答

请教一下数据量有100万条左右要什么配置?

易网网络 2013-03-27 15:18:02 192317浏览量 回答数 21

1

回答

foxmail 关联企业邮箱提示邮箱地址或者密码错误

2017-12-30 21:50:39 150605浏览量 回答数 1

249

回答

阿里云LNAMP(Linux + Nginx + Apache + MySQL + PHP)环境一键安装脚本

云代维 2014-02-14 15:26:06 302574浏览量 回答数 249
+关注
0
文章
14879
问答
推荐问答
相关电子书
更多
文娱运维技术
立即下载
《SaaS模式云原生数据仓库应用场景实践》
立即下载
《看见新力量:二》电子书
立即下载