当前位置:  开发笔记 > 数据库 > 正文

使用SQLITE的Long Lat coord之间的距离

如何解决《使用SQLITE的LongLatcoord之间的距离》经验,为你挑选了1个好方法。

我有一个sqlite数据库与长和拉特的商店,我想找到最近的5家商店.

所以下面的代码工作正常.

    if(sqlite3_prepare_v2(db, sqlStatement, -1, &compiledStatement, NULL) == SQLITE_OK) {


    while (sqlite3_step(compiledStatement) == SQLITE_ROW) {

        NSString *branchStr = [NSString stringWithUTF8String:(char *)sqlite3_column_text(compiledStatement, 0)];
        NSNumber *fLat = [NSNumber numberWithFloat:(float)sqlite3_column_double(compiledStatement, 1)];
        NSNumber *fLong = [NSNumber numberWithFloat:(float)sqlite3_column_double(compiledStatement, 2)];

        NSLog(@"Address %@, Lat = %@, Long = %@", branchStr, fLat, fLong);
        CLLocation *location1 = [[CLLocation alloc] initWithLatitude:currentLocation.coordinate.latitude longitude:currentLocation.coordinate.longitude];
        CLLocation *location2 = [[CLLocation alloc] initWithLatitude:[fLat floatValue] longitude:[fLong floatValue]];

        NSLog(@"Distance i meters: %f", [location1 getDistanceFrom:location2]);
        [location1 release];
        [location2 release];
    }       
}

我知道我到每个商店的距离.我的问题是.

    将距离放回sqlite行是否更好,当我逐步通过数据库时,我有一行.我怎么做?我是否使用UPDATE语句?有人有一段代码可以帮助我.

    我可以将sqlite读入一个数组然后对数组进行排序.您是否建议采用上述方法?这更有效吗?

最后,如果有人有更好的方法来获得最近的5家商店,那就爱听.



1> nevan king..:

在SQL中查找附近位置的最快方法是在SQL查询中使用Haversine公式.谷歌搜索sqlite和Haversine,你会发现一个实现.

这是我以前用过的一个:

http://www.thismuchiknow.co.uk/?p=71

推荐阅读
N个小灰流_701
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有