poI地址纠偏查询存储过程理解
1、POI存储过程查询
服务器类型:PostgreSQL
function name 函数名字 address_parse_no_save(lon float8, lat float8)
DECLARE METER_PER_DEGRESS float8;
PROJ4326 int;
user_point RECORD;--存储用户输入坐标转换为wkb格式的点记录
addr_table_num float8;
county RECORD;--存储区县地址的记录
road_sql_str varchar;
road_dist float8;
road_name varchar;
poi_sql_str varchar;
poi_dist float8;
poi_name varchar;
poi_angle varchar :='';
poi_x float8;
poi_y float8;
x float8;
y float8;
angle float8; BEGIN
METER_PER_DEGRESS := 111194.872221777;
PROJ4326 := ;
--地点
SELECT INTO user_point geomfromtext('POINT(' || lon ||' ' || lat ||')',PROJ4326) AS point,substr(st_geohash(geomfromtext('POINT(' || lon ||' ' || lat ||')',PROJ4326),),,)||'%' AS geohash7,substr(st_geohash(geomfromtext('POINT(' || lon ||' ' || lat ||')',PROJ4326),),,)||'%' AS geohash9,st_geohash(geomfromtext('POINT(' || lon ||' ' || lat ||')',PROJ4326),) geohash24 FROM (SELECT ) m1;
--省 区县
SELECT INTO county *,substr(split_part(m1.addr, ' ', ),,) province FROM addr_county m1 WHERE st_contains(m1.the_geom, user_point.point) LIMIT ; --地址解析
IF county.addr IS NULL THEN
RETURN '';-- 没有找到区县返回空字符串
ELSE
BEGIN --查找已解析的结果集,存在则返回结果。
IF county.province='浙江' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='云南' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='新疆' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='香港' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='西藏' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='台湾' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='四川' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='陕西' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='山西' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='山东' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='青海' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='宁夏' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='内蒙' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='辽宁' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='江西' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='吉林' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='湖南' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='湖北' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='黑龙' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='河南' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='北京' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='天津' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='河北' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='海南' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='贵州' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='广西' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='甘肃' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='福建' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='澳门' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='安徽' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='上海' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='重庆' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='江苏' THEN
BEGIN
addr_table_num:=;
END;
ELSEIF county.province='广东' THEN
BEGIN
addr_table_num:=;
END; END IF; road_sql_str := 'SELECT st_distance(geomfromtext(''POINT('|| lon ||' ' || lat ||')'','|| PROJ4326 ||'), m1.the_geom)*'||METER_PER_DEGRESS||' dist,m1."name" FROM addr_road_'||addr_table_num||' m1 WHERE m1.geohash like '''||user_point.geohash7||''' AND st_distance(geomfromtext(''POINT('|| lon ||' ' || lat ||')'','|| PROJ4326 ||'), m1.the_geom)*'||METER_PER_DEGRESS||'<=2000 ORDER BY st_distance(geomfromtext(''POINT('|| lon ||' ' || lat ||')'','|| PROJ4326 ||'), m1.the_geom)*'||METER_PER_DEGRESS||' LIMIT 1;';
EXECUTE road_sql_str INTO road_dist,road_name ; IF road_name IS NULL THEN
BEGIN
RETURN county.addr;
END;
ELSE
BEGIN
poi_sql_str := 'SELECT st_distance(geomfromtext(''POINT('|| lon ||' ' || lat ||')'','|| PROJ4326 ||'), m1.the_geom)*'||METER_PER_DEGRESS||' dist,m1."name",st_x( m1.the_geom) poi_x,st_y( m1.the_geom) poi_y FROM addr_poi_'||addr_table_num||' m1 WHERE m1.geohash like '''||user_point.geohash7||''' AND st_distance(geomfromtext(''POINT('|| lon ||' ' || lat ||')'','|| PROJ4326 ||'), m1.the_geom)*'||METER_PER_DEGRESS||'<=2000 ORDER BY st_distance(geomfromtext(''POINT('|| lon ||' ' || lat ||')'','|| PROJ4326 ||'), m1.the_geom)*'||METER_PER_DEGRESS||' LIMIT 1;';
EXECUTE poi_sql_str INTO poi_dist,poi_name,poi_x,poi_y ; IF poi_name IS NULL THEN
BEGIN
RETURN county.addr ||' '||road_name ||'(附近' || "floor"(road_dist) || '米)';
END;
ELSE
BEGIN x:=poi_x-lon;
y:=poi_y-lat;
IF x= THEN
x:=0.000001;
END IF;
angle:="floor"(atan((y)/(x))*/pi()); IF x> AND y> THEN
BEGIN
IF angle>= AND angle<= THEN
poi_angle:='西';
ELSEIF angle>= AND angle<= THEN
poi_angle:='西南';
ELSEIF angle>= AND angle<= THEN
poi_angle:='南';
END IF;
END;
ELSEIF x< AND y> THEN
BEGIN
IF angle<= AND angle>=- THEN
poi_angle:='东';
ELSEIF angle<=- AND angle>=- THEN
poi_angle:='东南';
ELSEIF angle<=- AND angle>=- THEN
poi_angle:='南';
END IF;
END;
ELSEIF x< AND y< THEN
BEGIN
IF angle>= AND angle<= THEN
poi_angle:='东';
ELSEIF angle>= AND angle<= THEN
poi_angle:='东北';
ELSEIF angle>= AND angle<= THEN
poi_angle:='北';
END IF;
END;
ELSEIF x> AND y< THEN
BEGIN
IF angle<= AND angle>=- THEN
poi_angle:='西';
ELSEIF angle<=- AND angle>=- THEN
poi_angle:='西北';
ELSEIF angle<=- AND angle>=- THEN
poi_angle:='北';
END IF;
END;
END IF;
RETURN county.addr ||' '|| road_name || '(附近' || "floor"(road_dist) || '米)' ||' '|| poi_name || '('||poi_angle||'方' || "floor"(poi_dist) || '米)';
END;
END IF;
END;
END IF; END;
END IF;
-- 没有找到任何数据,返回空字符串
RETURN '';
END;
2、POI存储过程理解
-- 调用function:-----------------
-- query-- SELECT kwt_address_parse_no_save('103.783432', '30.77454534');
-- reslt-- 四川省 成都市 生态大道(附近278米) 五福桥[村庄](西南方399米)
------------------------------------------------实现方案-------------------------------------------------
1、实际需求:根据一个经纬度解析出一个与物理世界对应的一个字符串地址描述。
2、实施方案:对经纬度禁行范围检索,逐级缩小搜索范围,从而更加精确地锁定目标地址。
实现步骤:
(1)对地址的详细程度做出分层级的定义,即依次定义:省,市,县,辖区,街道,路,门牌号,兴趣点,兴趣点距离,方向等
(2)确定传入参数的个数2,即:经度(longitude),纬度(latitude)
(3)首先获取一个经纬度在数据库中粗粒度的地址信息
(4)然后在对应的地址中去找省区县,如果没找到返回" "地址,否则继续下一步
(5)验证已解析的结果集,存在则返回结果{
1)、逐级比较:省,市,县,辖区,街道,路,门牌号,兴趣点
2)、检索兴趣点的时候解析经纬度与最近的道路和兴趣点进行匹配,通过经纬度算出方向和距离
3)、拼接查询出来的层级定义的变量,并返回字符串组合
}。
3、涉及算法:
(1)、经纬度距离计算:
public static class Distance{ private static String unit; //距离单位 private static double distance;//距离大小
/**
*@param utype:距离单位:"m"/"km"
*@param latlng1 经纬度
*@param latlng2 经纬度
*/
public double getDistance(String utype,String latlng1,String latlng2) {
String []latlng_1=latlng1.split(",");
String []latlng_2=latlng2.split(",");
double lata=Double.parseDouble(latlng_1[0]);
double lnga=Double.parseDouble(latlng_1[1]);
double latb=Double.parseDouble(latlng_2[0]);
double lngb=Double.parseDouble(latlng_2[1]);
double distance= 111119*Math.sqrt(Math.pow(lnga - lngb, 2) +Math.pow(lata - latb, 2));
String num=distance+"";
distance =Double.parseDouble(num);
if("km".equals(utype)){
distance=Math.round(distance*100)/100000;
}else{
distance=Math.round(distance*100)/100;
}
unit = utype;
} }
(2)、经纬度角度计算:
atan=(p1.y-p2.y)/(p2.x-p1.x))*180/Math.PI
poI地址纠偏查询存储过程理解的更多相关文章
- SQLServer分页查询存储过程
项目中用到的SQLServer分页查询存储过程. [存储过程] create PROCEDURE prcPageResult -- 获得某一页的数据 -- @currPage int = 1, ...
- MySQL 存储过程理解
/********************************************************************************* * MySQL 存储过程理解 * ...
- MySQL 查询 存储过程 视图 触发器 函数 索引 建表语句 数据库版本 当前登录用户 当前数据库名称
MySQL 查询 存储过程 视图 触发器 函数 索引 建表语句 数据库版本 当前登录用户 当前数据库名称 INFORMATION_SCHEMA.TABLES INFORMATION_SCHEMA. ...
- MSSQL·查询存储过程中的关键字
阅文时长 | 0.22分钟 字数统计 | 408字符 主要内容 | 1.引言&背景 2.声明与参考资料 『MSSQL·查询存储过程中的关键字』 编写人 | SCscHero 编写时间 | 20 ...
- 大数据学习day20-----spark03-----RDD编程实战案例(1 计算订单分类成交金额,2 将订单信息关联分类信息,并将这些数据存入Hbase中,3 使用Spark读取日志文件,根据Ip地址,查询地址对应的位置信息
1 RDD编程实战案例一 数据样例 字段说明: 其中cid中1代表手机,2代表家具,3代表服装 1.1 计算订单分类成交金额 需求:在给定的订单数据,根据订单的分类ID进行聚合,然后管理订单分类名称, ...
- sqlserver2008 数据库中查询存储过程的的创建修改和执行时间,以及比较常见的系统视图和存储过程
因为各种原因数据库中存在大量无用的存储过程,想查询存储过程的最后执行情况,处理长期不使用的存储过程 下面这条语句可以查询存储过程创建 修改和执行的最后时间: SELECT a.name AS 存储过程 ...
- T-SQL查询进阶--理解SQL Server中索引的概念,原理
简介 在SQL Server中,索引是一种增强式的存在,这意味着,即使没有索引,sql server仍然可以实现应有的功能,但索引可以在大多数情况下提升查询性能,在OLAP(On line Trans ...
- 【原创】SQL分页查询存储过程
------------------------------------- -----作者:张欣宇 -----时间:2013-06-28 -----简介:根据参数和条件分页查询 ----------- ...
- 【转】T-SQL查询进阶—理解SQL Server中的锁
简介 在SQL Server中,每一个查询都会找到最短路径实现自己的目标.如果数据库只接受一个连接一次只执行一个查询.那么查询当然是要多快好省的完成工作.但对于大多数数据库来说是需要同时处理多个查 ...
随机推荐
- 配置文件入门 - WebConfig.config常用配置节点介绍
一.配置文件入门 .Net提供了一种保存项目配置信息的办法,就是利用配置文件,配置文件的后缀一般是.config.在WinForm程序中配置文件一般是App.config.在Asp.net中一般默认是 ...
- 软件架构 "4+1" 视图模型
1995年,Philippe Kruchten在<IEEE Software>上发表了题为<The 4+1 View Model of Architecture>的论文,引起了 ...
- css案例学习之div ul li a 实现导航效果
效果 代码 <html> <head> <title>无需表格的菜单</title> <style> body{ background-co ...
- 剑指offer-面试题13.在O(1)时间删除链表节点
题目:给定单向链表的头指针和一个节点指针,定义一个函数在O(1)时间删除该节点. 链表节点与函数的定义如下. 通常我们删除某个节点都是从头开始遍历到需要删除节点的前一个节点. 然后使得该节点的next ...
- MongoDB C Driver and APIinstances linux MongoDB安装配置
<一,linux平台MongoDB安装配置>在这我们使用的Centos6 yum部署的,你想搞编译,自个干!
- 对Linux 新手非常有用的20 个命令
你打算从Windows换到Linux上来,还是你刚好换到Linux上来?哎哟!!!我说什么呢,是什么原因你就出现在我的世界里了.从我以往的经验来说,当我刚使用Linux,命令,终端啊什么的,吓了我一跳 ...
- html 表格中文字的背景色
- React-Native个人信息界面
最近在做一个小练习项目,用户登陆后需要跳转到用户登录信息界面,加班半个小时终于将界面的布局搞定.接触Rect-Native也有一段时间了,以前没有做过ios,只做过android,就布局和开发效率上来 ...
- 输出jq对象
console.log($()); 效果截图:
- 获取设备、APP的一些信息
获取设备的一些信息: UIDevice *device = [UIDevice currentDevice]; @property(nonatomic,readonly,strong) NSStrin ...