qq_35659430 2017-05-26 09:56 采纳率: 0%
浏览 1539
已结题

求解决插入时间段不会与原数据时间段发生重叠,保证时间段唯一性的办法

如原数据为:
startTime             endTime
2011-06-04 08:05:06 2011-06-07 08:05:06
2011-06-09 09:05:06 2011-11-09 09:05:06
插入一条数据,前提保证插入的必须绝对插入,时间段不能修改,那么就会有以下几种情况:
第一种:不重叠 可以正常插入,如:
startTime             endTime
2011-06-07 09:00:00 2011-06-09 09:00:00

第二种:插入数据和一条数据发生重叠,且与数据结束时间发生中谍,则让原数据提前2分钟结束,如
startTime             endTime
2011-06-06 09:00:00 2011-06-09 09:00:00
强制插入后数据为:
startTime             endTime
2011-06-04 08:05:06 2011-06-06 08:58:00
2011-06-06 09:00:00 2011:06-09 09:00:00
2011-06-09 09:05:06 2011-11-09 09:05:06

第三种: 插入数据和一条数据发生重叠,且与数据开始时间发生重叠,则让原数据推迟2分钟开始,如
startTime             endTime
2011-06-02 09:00:00 2011-06-04 09:00:00
强制插入后数据为:
startTime             endTime
2011-06-02 09:00:00 2011-06-04 09:00:00
2011-06-04 09:02:00 2011-06-07 08:05:06
2011-06-09 09:05:06 2011-11-09 09:05:06

第四种: 与多条数据发生重叠,且不包含多条数据:则对原数据的开始时间和结束时间进行提前或推迟2分钟:如
startTime             endTime
2011-06-06 09:00:00 2011-06-10 09:00:00
强制插入后数据为:
startTime             endTime
2011-06-04 08:05:06 2011-06-06 08:58:00
2011-06-06 09:00:00 2011-06-10 09:00:00
2011-06-10 09:00:00 2011-11-09 09:05:06

第五种:与多条数据发生重叠, 且完全包含一条广告,则修改当前数据的开始时间和原数据的结束时间,如
startTime             endTime
2011-06-06 09:00:00 2011-11-10 09:00:00
强制插入后数据为:
startTime             endTime
2011-06-04 08:05:06 2011-06-06 08:58:00
2011-06-06 09:00:00 2011-06-09 09:03:00
2011-06-09 09:05:06 2011-11-09 09:05:06
第六种: 完全包含多条数据, 则不让插入


    oracle数据库
  • 写回答

2条回答

  • dboy_zhu 2017-05-27 05:16
    关注

    要用存储过程来实现,什么数据库?

    评论

报告相同问题?

悬赏问题

  • ¥20 ML307A在使用AT命令连接EMQX平台的MQTT时被拒绝
  • ¥20 腾讯企业邮箱邮件可以恢复么
  • ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?
  • ¥15 错误 LNK2001 无法解析的外部符号
  • ¥50 安装pyaudiokits失败
  • ¥15 计组这些题应该咋做呀
  • ¥60 更换迈创SOL6M4AE卡的时候,驱动要重新装才能使用,怎么解决?
  • ¥15 让node服务器有自动加载文件的功能
  • ¥15 jmeter脚本回放有的是对的有的是错的
  • ¥15 r语言蛋白组学相关问题