standardize_address — 使用词法、地名词典和规则表,返回输入地址的 stdaddr 格式。
stdaddr standardize_address(
text lextab, text gaztab, text rultab, text address)
;
stdaddr standardize_address(
text lextab, text gaztab, text rultab, text micro, text macro)
;
返回使用 词法表 表名、地名词典表 和 规则表 表名以及地址的输入地址的 stdaddr 格式。
变体 1:将地址作为单行输入。
变体 2:将地址作为两个部分输入。一个 micro
部分,包含邮政地址的标准第一行,例如 门牌号 街道
;以及一个 macro
部分,包含地址的标准邮政第二行,例如 城市,州 邮政编码 国家
。
可用性:2.2.0
此方法需要 address_standardizer 扩展。
使用 address_standardizer_data_us 扩展
CREATE EXTENSION address_standardizer_data_us; -- only needs to be done once
变体 1:单行地址。这对于非美国地址效果不佳
SELECT house_num, name, suftype, city, country, state, unit FROM standardize_address('us_lex', 'us_gaz', 'us_rules', 'One Devonshire Place, PH 301, Boston, MA 02109');
house_num | name | suftype | city | country | state | unit ----------+------------+---------+--------+---------+---------------+----------------- 1 | DEVONSHIRE | PLACE | BOSTON | USA | MASSACHUSETTS | # PENTHOUSE 301
使用与 tiger 地理编码器打包的表。此示例仅在您安装了 postgis_tiger_geocoder
时有效。
SELECT * FROM standardize_address('tiger.pagc_lex', 'tiger.pagc_gaz', 'tiger.pagc_rules', 'One Devonshire Place, PH 301, Boston, MA 02109-1234');
为了更易于阅读,我们将使用 hstore 扩展转储输出 CREATE EXTENSION hstore; 您需要安装它
SELECT (each(hstore(p))).* FROM standardize_address('tiger.pagc_lex', 'tiger.pagc_gaz', 'tiger.pagc_rules', 'One Devonshire Place, PH 301, Boston, MA 02109') As p;
key | value ------------+----------------- box | city | BOSTON name | DEVONSHIRE qual | unit | # PENTHOUSE 301 extra | state | MA predir | sufdir | country | USA pretype | suftype | PL building | postcode | 02109 house_num | 1 ruralroute | (16 rows)
变体 2:作为两部分地址
SELECT (each(hstore(p))).* FROM standardize_address('tiger.pagc_lex', 'tiger.pagc_gaz', 'tiger.pagc_rules', 'One Devonshire Place, PH 301', 'Boston, MA 02109, US') As p;
key | value ------------+----------------- box | city | BOSTON name | DEVONSHIRE qual | unit | # PENTHOUSE 301 extra | state | MA predir | sufdir | country | USA pretype | suftype | PL building | postcode | 02109 house_num | 1 ruralroute | (16 rows)