- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在处理我正在处理的应用程序时遇到了一些问题,我希望得到一些指导。
我有一个简单的预订系统:每件商品都有一个标准价格,但有时价格可能会发生变化。
例如:
标准价格是100/天
从 10 月开始。 1 日
到 二月。每年1号
,价格80/天
来自 6 月。 1 日
到 八月。每年31号
价格为120/天
[...] 最多 6 个不同的价格变化(季节)
因为这是每年发生一次,我只需要月份和日期,但我不知道如何将这些值存储在数据库中。我在考虑有两个字段,一个用于月份,一个用于日期,其中包含数值(01-12
表示月份,01-31
表示日期)。这些值是用户自己设置的,是相对于item本身而言的,并不是对每个人都是固定的。
问题是,当有人进行预订时,我需要检查价格是否需要更改,但我不明白如何构建查询来进行检查。更糟糕的是,预订期间的价格可能有多个值。
按照上面的示例,如果我要从 9 月开始预订商品。 1 号(当年)
到 7 月。 1st(明年)
,价格如下:
100/天 从 9 月开始。 1 日
到 9 月。 30 日
80/天 从 10 月开始。 1 日
到 二月。第一名
100/天 从 2 月开始2 日
到 5 月 31 日
120/天 从 6 月开始。 1 日
到 七月。第一名
有没有什么方法可以检查这些情况,而不必每天循环并检查数据库是否匹配?
谢谢
最佳答案
检查日期时可以使用MySQL的date_format
函数。
例如:
select date_format('2016-05-18', '%m%d');
+-----------------------------------+
| date_format('2016-05-18', '%m%d') |
+-----------------------------------+
| 0518 |
+-----------------------------------+
1 row in set (0,01 sec)
因此,您可以使用简单的时间间隔进行检查:今天是 0518
,它介于 2 月 2 日和 5 月 31 日之间:
0202 <= 0518 <= 0531
完整示例:
desc mytable;
+-----------+---------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-----------+---------+------+-----+---------+-------+
| date_from | char(4) | YES | | NULL | |
| date_to | char(4) | YES | | NULL | |
| price | int(11) | YES | | NULL | |
+-----------+---------+------+-----+---------+-------+
3 rows in set (0,00 sec)
select * from mytable;
+-----------+---------+-------+
| date_from | date_to | price |
+-----------+---------+-------+
| 0901 | 0930 | 100 |
| 1001 | 0201 | 80 |
| 0202 | 0531 | 100 |
| 0601 | 0701 | 120 |
+-----------+---------+-------+
4 rows in set (0,00 sec)
示例查询:
select price, date_from, date_to from mytable where date_format(now(), '%m%d') between date_from and date_to;
+-------+-----------+---------+
| price | date_from | date_to |
+-------+-----------+---------+
| 100 | 0202 | 0531 |
+-------+-----------+---------+
1 row in set (0,01 sec)
编辑:
阅读您对@FelipeDuarte 的回答的评论...从 10/01(10 月 1 日)到 02/01(2 月 1 日),我们需要考虑新的一年...
你可以通过将时间段分成两个部分来作弊:10/01 到 12/31 和 01/01 到 02/01
关于PHP 和 MySQL : Comparing month and day with dynamic year,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37308742/
我经常有一个 Comparator 类型,而我需要一个 Comparable 类型,反之亦然。是否有可重用的 JDK API 可以相互转换?类似的东西: public static Comp
我怎么能写这个 Comparator sort = (i1, i2) -> Boolean.compare(i2.isOpen(), i1.isOpen()); 像这样(代码不起作用): Compa
请帮助她。我有一个错误 Collections.sort(var4, new Comparator() { public int compare(TreeMap var1, TreeMa
学习 Kotlin,我试图了解 Java 的 Comparator接口(interface)有效 - 主要是 compare() 函数,这样我就可以利用它。 我已经尝试阅读 compare() 的文档
我有以下程序 List numbers = Arrays.asList("10", "68", "97", "9", "21", "12"); Collections.sort(numbers, (
我想根据嵌套类的属性对如下所示的列表进行排序。 class Test { private NestedClass nestedClass; private AnotherNes
我很好奇“Beyond Compare”的算法是如何工作的? 我猜想他们使用了一种标准的(众所周知的?)算法来实现“字符与字符”的比较。你知道这个算法的名字吗?谢谢 最佳答案 Beyond Compa
这个问题已经有答案了: How does the sort() method of the Collection class call the Comparable's compareTo()? (1
这个问题已经有答案了: 已关闭12 年前。 Possible Duplicates: difference between compare() and compareTo() Java: What i
我被要求为某个类实现Comparable或Compartor,我们称之为V。 假设我有一个 V 的 Collection 或 Set(还不确定,但我认为这并不重要)。 V 有一个方法,可以评估它的“权
我正在查看Java8中实现的Comparator.comparing方法的源代码 这是代码 public static Comparator comparing( Function
假设我有一个类 ClassA,它的属性是 ClassB: public ClassA { private String attr; private ClassB classB; } p
我有一个自定义比较器,其比较逻辑如下: List l = new ArrayList(); l.add("tendercoupon"); l.add("giftcard
我正在努力实现一个处理 Comparator 和 Comparable 接口(interface)的层次结构。我不清楚的几件事: 如果我将比较器添加到比较器链中,这段代码究竟意味着什么 chain.a
正在关注 this question关于按另一个列表对列表进行排序,我尝试做同样的事情 - 但由于某种原因它对我不起作用。我错过了什么? List nums = Arrays.asList(5
假设我有一个像这样的领域模型: class Lecture { Course course; ... // getters } class Course { Teache
在表达式 > 中像这样的签名 public static > foo(T x) { ... } T的描述递归地依赖于Comparable . 如果T延伸Comparable ,和Comparable延
所有“数字”比较器(例如 Comparer.Default 、 Comparer.Default 等)返回 -1 的原因是什么? , 0或 1 ,但是 Comparer.Default和 Compar
(如果这是重复的,请指出正确的答案!我搜索并阅读了几个(> 5)个相关问题,但似乎没有一个是正确的。还查看了泛型常见问题解答和其他来源...) 当一个集合类接受一个比较器时,它应该具有 Compara
SBCL 1.3.1 综上所述,a是一个列表,'(7),b通过setq sbcl This is SBCL 1.3.1.debian, an implementation of ANSI Common
我是一名优秀的程序员,十分优秀!