1

我正在使用Multidatepicker,所以我的数据库中有如下日期:

ID    POST  KEY                  VALUE
1     1     multipledates        20151020, 20151015, 20151101
2     2     multipledates        20151103
3     3     multipledates        20151022, 20151010, 20151202, 20160410
...

然后我有'date_start'和'date_end'。我需要在这些日期之间选择日期。

此 SQL 查询仅适用于我的 ID2 示例(因为它没有逗号)

SELECT ... BETWEEN $date_start AND $date_end

解决方案是使用类似“LIKE”的东西,但如果可能的话不要:

SELECT ... BETWEEN LIKE '%$date_start%' AND LIKE '%$date_end%'

有任何想法吗?

谢谢。

4

1 回答 1

3

您肯定应该重新设计您的架构。

但作为一个研究案例,您可以:

http://sqlfiddle.com/#!9/22755/4

SELECT t.id,
   t.date
FROM (SELECT
  t1.id,
  DATE(SUBSTRING_INDEX(SUBSTRING_INDEX(t1.value, ',', numbers.n), ',', -1)) `date`
FROM
  numbers 
  INNER JOIN t1
  ON CHAR_LENGTH(t1.value)
     -CHAR_LENGTH(REPLACE(t1.value, ',', ''))>=numbers.n-1
ORDER BY
  id, n ) t
WHERE t.date BETWEEN $date_start AND $date_end

请注意,此解决方案希望您的numbers表中的记录值从 1 到value列表列中的最大元素数。

(c) 基于https://stackoverflow.com/a/17942691/4421474的代码

于 2015-10-15T17:08:41.757 回答