$$
LANGUAGE plpgsql STABLE;
+DROP TYPE IF EXISTS addressdata_place;
+CREATE TYPE addressdata_place AS (
+ place_id BIGINT,
+ country_code VARCHAR(2),
+ housenumber TEXT,
+ postcode TEXT,
+ class TEXT,
+ type TEXT,
+ name HSTORE,
+ address HSTORE,
+ centroid GEOMETRY
+);
-- Compute the list of address parts for the given place.
--
RETURNS setof addressline
AS $$
DECLARE
- place RECORD;
+ place addressdata_place;
location RECORD;
current_rank_address INTEGER;
location_isaddress BOOLEAN;
-- first query osmline (interpolation lines)
IF in_housenumber >= 0 THEN
SELECT parent_place_id as place_id, country_code,
- in_housenumber::text as housenumber, postcode,
+ in_housenumber as housenumber, postcode,
'place' as class, 'house' as type,
- null::hstore as name, null::hstore as address,
+ null as name, null as address,
ST_Centroid(linegeo) as centroid
INTO place
FROM location_property_osmline
-- %NOTIGERDATA% IF 0 THEN
IF place IS NULL AND in_housenumber >= 0 THEN
SELECT parent_place_id as place_id, 'us' as country_code,
- in_housenumber::text as housenumber, postcode,
+ in_housenumber as housenumber, postcode,
'place' as class, 'house' as type,
- null::hstore as name, null::hstore as address,
+ null as name, null as address,
ST_Centroid(linegeo) as centroid
INTO place
FROM location_property_tiger
SELECT parent_place_id as place_id, 'us' as country_code,
housenumber, postcode,
'place' as class, 'house' as type,
- null::hstore as name, null::hstore as address,
+ null as name, null as address,
centroid
INTO place
FROM location_property_aux
SELECT parent_place_id as place_id, country_code,
null::text as housenumber, postcode,
'place' as class, 'postcode' as type,
- null::hstore as name, null::hstore as address,
- null::geometry as centroid
+ null as name, null as address,
+ null as centroid
INTO place
FROM location_postcode
WHERE place_id = in_place_id;
select coalesce(linked_place_id, place_id) as place_id, country_code,
housenumber, postcode,
class, type,
- null::hstore as name, address,
- null::geometry as centroid
+ null as name, address,
+ null as centroid
INTO place
FROM placex where place_id = in_place_id;
END IF;
--RAISE WARNING '%',location;
IF location.rank_address < 4 THEN
-- no country locations for ranks higher than country
- place.country_code := NULL;
+ place.country_code := NULL::varchar(2);
ELSEIF place.country_code IS NULL AND location.country_code IS NOT NULL THEN
place.country_code := location.country_code;
END IF;
FOR location IN
SELECT placex.place_id, osm_type, osm_id, name, class, type,
coalesce(extratags->'linked_place', extratags->'place') as place_type,
- admin_level, fromarea, isaddress,
+ admin_level, fromarea, isaddress and linked_place_id is NULL as isaddress,
CASE WHEN rank_address = 11 THEN 5 ELSE rank_address END as rank_address,
distance, country_code, postcode
FROM place_addressline join placex on (address_place_id = placex.place_id)