我在sqlite列中将日期存储为字符串,格式为YYYY-MM-DD(年份日期和月份不分为三列)现在我需要进行查询,该查询给出了最接近日期的结果查询作为第一个条目的日期,顺序按升序排列.这里我对这一年不感兴趣,只有月份和日期很重要.根据我的要求,我应该处理什么类型的查询,以便按顺序获取这些日期.
例:
我有约会
1980-01-11,1999-08-03,2013-12-03
查询后我应该得到:(根据当前日期,考虑到它是2013年12月1日)
2013-12-03,1999-01-11,1980-08-03(仅基于月和日排序).
我也从这里参考:MySQL query to sort upcoming birthdays based on current date但是不太清楚.我认为Unix时间戳作为存储在日期列中的长值将有助于我感兴趣的查询类型,而不是简单的日期格式.
解决方法:
以下将做:
SELECT *FROM _tableORDER BY SUBSTR(DATE('Now'), 6)>SUBSTR(birthdate, 6), SUBSTR(birthdate, 6)
在SQL Fiddle检查.
SUBSTR(日期,6)将删除年份部分.出生日期必须以MM-DD排序,但首先应该显示将在今天之后发生的那些,然后是在今天之前发生的那些.
SUBSTR(DATE(‘Now’),6)> SUBSTR(birthdate,6)将为生日MM-DD返回0,大于或等于今天的MM-DD,否则为1.因此,第一个表达式将在提交日期之后ORDER过去的日期.第二个参数只是ORDER日期的MM-DD.
请参见SQL Fiddle中的分步骤.
总结以上是内存溢出为你收集整理的android – 订购日期并根据当前日期(出生日列表)SQLite检索结果全部内容,希望文章能够帮你解决android – 订购日期并根据当前日期(出生日列表)SQLite检索结果所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)