我有一个包含 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 ;