mysql中datetime列如何做筛选?
PHP中文网
PHP中文网 2017-04-17 16:31:29
0
2
483

1,数据库中有个数据的创建时间的列 F1,类型是 datetime 类型
2,现在准备做个根据给定时间来筛选数据的功能
3,现在的SQL代码如下:

select * from TABLE where F1 > '2017-01-01 12:23:33'

上面的 > 可以是 < 或者 <=,重点是没用 between and,根据观察发现这么去筛的时候出来的数据有可能不太对。

4,个人猜猜:由于最终转换成字符串的形式比较,所以感觉像是在做字符串比较而非时间比较导致数据不对。

5,问题:想问下大家有什么方法没用可以使出来的数据是正确的,说把列改类型是不可能了,只能从SQL语句上想办法了

PHP中文网
PHP中文网

认证高级PHP讲师

répondre à tous(2)
PHPzhong

datetime这样比较是没有问题的 即使转换成字符比较效果也是一样的 你的数据不对怎么不对的 要找找其他的原因

迷茫

解决方法就是采用 unix_timestamp 转一下,最终使用整数形式比较一定是没问题的。

请问下大家,不能直接使用字符串比较的原因是啥?

Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!