我有一个包含 3 列的数据库:
user_id | lat | lon
1 |-1.403976 | 53.428692
2 |-1.353276 | 55.224692
etc etc
lat 和 lon 都设置为十进制字段。我正在运行一个与此类似的查询,但它没有根据大于和小于给定的经纬度数字进行过滤:
SELECT * FROM `table` WHERE `lat` < '-1.399999' AND 'lat' > '-1.300000'
AND 'lon' < '55.555555' AND > '53.000000'
这个查询只返回表中的每一行,我不知道为什么?这与设置为小数的字段有关吗?
我希望有人能提供帮助 - 如果你知道的话,我知道这可能是一个简单的答案。
根据评论 - 这是创建表:
CREATE TABLE IF NOT EXISTS `members` (
`user_id` int(10) NOT NULL AUTO_INCREMENT,
`lat` decimal(8,6) NOT NULL,
`lon` decimal(8,6) NOT NULL,
UNIQUE KEY `user_id` (`user_id`),
) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=136 ;
最佳答案
问题是你用单引号包装列名,迫使十进制值与字符串文字进行比较。列名和表名都是标识符而不是字符串文字,所以它们不应该用单引号括起来。
AND `lat` > '-1.300000'
AND `lon` BETWEEN '55.555555' AND '53.000000' -- use between here
关于mysql - 大于和小于 MySql 查询失败并显示十进制字段,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/15823450/