mysql怎么获取到经纬度_2015.03.01 mysql SQL语句获取两个经纬度之间的距离

方式一:SQL语句

SQL拼接

StringBuffer sql = new StringBuffer("SELECT b.id, b.jd, b.wd, b.`name`, b.address, b.agree_count, b.flower_count, b.egg_count, b.discuss_count, b.membership_count, b.sale_info, b.pics, ");

sql.append(" round( 6378.138 * 2 * asin( sqrt( pow( sin((

b.wd * pi() / 180 - ");

sql.append(

wd);

sql.append(" * pi() / 180 ) / 2 ), 2 ) + cos(

b.wd * pi() / 180) * cos(");

sql.append(

wd);

sql.append(" * pi() / 180) * pow( sin((

b.jd * pi() / 180 -");

sql.append(

jd);

sql.append(" * pi() / 180 ) / 2 ), 2 ))) * 1000 ) AS distance");

sql.append(" FROM `business` b");

SQL语句如下:

SELECT b.id, b.jd, b.wd, b.`name`, b.address, b.agree_count, b.flower_count, b.egg_count, b.discuss_count, b.membership_count, b.sale_info, b.pics, round( 6378.138 * 2 * asin( sqrt( pow( sin(( b.wd * pi() / 180 - 30.544969 * pi() / 180 ) / 2 ), 2 ) + cos(b.wd * pi() / 180) * cos(30.544969 * pi() / 180) * pow( sin(( b.jd * pi() / 180 - 104.062414 * pi() / 180 ) / 2 ), 2 ))) * 1000 ) AS distanceFROM `business` b WHERE 1 = 1 ORDER BY distance ASC LIMIT 0, 100

方式二:百度定位SDK

// 【注意参数的顺序:纬度、经度】当前位置距离店家的距离 LatLng(double latitude, double longitude)

LatLng startLocation = new LatLng(currentLatitude, currentLongitude);

// 当前位置(起)

LatLng endLocation   = new LatLng(Double.parseDouble(sale.wd), Double.parseDouble(sale.jd));

// 目标位置(止)

Double

distance= DistanceUtil.getDistance(endLocation, startLocation); // 距离

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值