The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.

NAME

FIAS::SQL - Модуль для минимальной работы с данными из базы ФИАC https://fias.nalog.ru/FiasInfo.aspx

VERSION

version 0.04

    # Создание объекта, подключение к базе
    my  $fias = FIAS::SQL->new(
                                db_connection => {
                                    dsn       => 'DBI:mysql:database=fias;host=localhost;port=3306';',
                                    login     => 'user',
                                    password  => 'pass',
                                },
                                # Опциональные параметры
                                additional_connection_params => {
                                    # выставляем флаг UTF-8 для нормальной работы с unicode( опционально)
                                    mysql_enable_utf8 => 1,
                                }
    );

    # автоматическое скачивание и распаковка пока не реализованы
    # файлы брать здесь https://fias.nalog.ru/Updates.aspx ( Полная БД ФИАС, DBF )

    # Загрузка базы из текущей директории
    $fias->load_files( '.' );

    # Получение всех записей первого уровня( регионов )
    my $regions   = $fias->get_address_objects( aolevel=>'region' );

    # Получение всех субъектов региона
    my $under_region = $fias->get_address_objects( parentguid => 'ee594d5e-30a9-40dc-b9f2-0add1be44ba1' );

    # Получение всех строений находящихся на адресном объекте с aoguid '00001be9-7886-4c7b-bcfe-74bdd601b81a'
    my $houses = $fias->get_houses_for_address_objects( '00001be9-7886-4c7b-bcfe-74bdd601b81a' );

    # Получение всех помещений находящихся в строении с houseid '000012ba-2754-425c-ba4a-4c35d0771045'
    my $rooms =  $fias->get_rooms_of_address_objects( '000012ba-2754-425c-ba4a-4c35d0771045' );

new Создание объекта

    %params
        db_connection -- параметры соединения к базе
            dsn         -- DBI Data Source Name
            login       -- логин для подключения к базе
            password    -- пароль для подключения к базе
            # Опционально
            additional_connection_params {
                # флаг для подключения к MySQL базе( опционально )
                mysql_enable_utf8 => 1
            }

load_files Метод для загрузки dbf файлов в базу $directory -- папка с DBF файлами

get_address_objects Получение адресных объектов по уровню и родителю %params parentguid -- id родительского объекта aolevel -- уровень получаемых объектов Уровень объекта может принимать только нижеперечисленные значения соответсвия между строками и числами указаны в хеше $LEVELS region(1) – уровень региона district(3) – уровень района settlement(35) – уровень городских и сельских поселений town(4) – уровень города inhabitet_locality(6) – уровень населенного пункта planning_structure(65) – планировочная структура street(7) – уровень улицы stead(75) – земельный участок structure(8) – здания, сооружения, объекта незавершенного строительства premises(9) – уровень помещения в пределах здания, сооружения

    Функция возвращает массив из hashrefs квартир в формате
    {
        'aolevel' => '1',
        'shortname' => 'обл',
        'offname' => 'Брянская',
        'aoguid' => 'f5807226-8be0-4ea8-91fc-39d053aec1e2'
    }
    aoguid  --  Глобальный уникальный идентификатор адресного объекта
    aolevel --  Уровень адресного объекта
    offname  --  Официальное наименование
    shortname -- Краткое наименование типа объекта

get_sublevels_for_objects Получение списка уровней дочерних адресных объектов по id родителя parentguid -- id родительского объекта Функция возвращает arrayref уровней

get_data_for_object_by_aoguid Получение данных адресного объекта по id aoguid -- id объекта Функция возвращает hashref c данными адресного объекта

get_houses_of_address_objects Функция принимает на вход $aoguid -- родительский объект для всех домов. Функция возвращает массив из hashrefs квартир в формате { 'buildnum' => '', 'housenum' => '25', 'strucnum' => '', 'aoguid' => '53edf165-0dc2-42b7-81b5-6a87ab08c7df', 'houseguid' => '65e2fbbc-72ac-4241-b5ca-fa40eb5307fe', 'postalcode' => '241020' }; housenum -- номер дома buildnum -- номер корпуса strucnum -- номер строения postalcode -- Почтовый индекс TODO добавить join для hststat?

get_data_for_house_by_houseguid Получение данных дома по id houseguid -- id объекта Функция возвращает hashref c данными дома

get_rooms_of_address_objects Функция принимает на вход $houseguid -- уникальный id дома

    Функция возвращает  массив из hashrefs квартир в формате
    {
        'postalcode' => '241020',
        'roomnumber' => '',
        'roomtype' => 'Не определено',
        'flatnumber' => '2',
        'flattype' => 'квартира',
        'roomguid' => '5039b82c-7975-4494-8920-22ad28cc130b',
        'houseguid' => 'cca694e2-2cf2-4f0c-8f5a-dec652833c1b'
    },
    flatnumber -- номер квартиры, офиса и прочего
    flattype   -- тип квартиры ( из справочника flattype )
    houseguid  -- Глобальный уникальный идентификатор родительского объекта (дома)
    roomguid   -- Глобальный уникальный идентификатор помещения
    postalcode -- Почтовый индекс
    roomnumber -- Номер комнаты или помещения
    roomtype   -- тип комнаты ( из справочника roomtype )

get_data_for_room_by_roomguid Получение данных квартиры по id roomguid -- id квартиры Функция возвращает hashref c данными квартиры

get_parent_record_chain_by_aoguid Получение цепочки элементов до верхнего уровня по aoguid aoguid -- id нижнего элемента Функция возвращает arrayref c данными записей [ { guid "d967adce-0608-400f-983f-d64ca6e22547", level "planning_structure" }, { guid "978c4d8c-f724-43b1-aa95-0c1fc49dc6b7", level "town" }, { aoguid "2dd692c1-fc95-41a2-86a1-6a83f47914fe", level "district" }, { guid "88cd27e2-6a8a-4421-9718-719a28a0a088", level "region" } ]

get_parent_record_chain_by_houseguid Получение цепочки элементов до верхнего уровня по aoguid houseguid -- id дома Функция возвращает arrayref c данными записей [ { guid "cca694e2-2cf2-4f0c-8f5a-dec652833c1b", level "house" }, { guid "dadfc561-e091-44b5-a07c-8d046529dfd4", level "street" }, { guid "414b71cf-921e-4bfc-b6e0-f7395d16aaef", level "town" }, { guid "f5807226-8be0-4ea8-91fc-39d053aec1e2", level "region" } ]

get_parent_record_chain_by_roomguid Получение цепочки элементов до верхнего уровня по aoguid roomguid -- id помещения Функция возвращает arrayref c данными записей [ { guid "4f13298c-e20b-4144-b90e-897ef80de2f2", level "room" }, { guid "cca694e2-2cf2-4f0c-8f5a-dec652833c1b", level "house" }, { guid "dadfc561-e091-44b5-a07c-8d046529dfd4", level "street" }, { guid "414b71cf-921e-4bfc-b6e0-f7395d16aaef", level "town" }, { guid "f5807226-8be0-4ea8-91fc-39d053aec1e2", level "region" } ]

_check_record_actuality Проверка записи из DBF на актуальность $record -- запись взятая из DBF,

        возвращаем 1(неактуально) или 0(актуально)

_get_table_fields Функция для получения необходимых полей для записи в таблицы, значения полей берём из %table_config $sql_table_name -- имя таблицы из DBF полученное обрезанием номера региона и расширения HOUSE89.DBF превращается в HOUSE $dbf_table -- объект XBase для получения полей из файлов не упомянутых в $table_config

_create_table собираем комманду 'CREATE TABLE' для создания таблицы в базе $sql_table_name -- имя таблицы из DBF полученное обрезанием номера региона и расширения HOUSE89.DBF превращается в HOUSE $dbf_table -- объект XBase для получения параметров полей в таблице Для каждой таблицы получаем на выходе SQL комманду 'CREATE TABLE ...'

_convert_data конвертируем данные полученные из DBF в соответствующие данные для SQL $record -- запись $dbf_table -- объект XBase для получения данных поля DBF файла $sql_table_name -- имя таблицы из DBF полученное обрезанием номера региона и расширения HOUSE89.DBF превращается в HOUSE

    На выходе получаем данные DBF удовлетворяющие стандарту SQL перечисленные через запятую

_get_formatted_date Получаем дату для SQL из даты для DBF $date -- слитная дата из 8 цифр

    Возвращаем дату разделённую дефисами для нормального помещения в SQL

_get_quoted_text Экранируем и декодируем полученный текст из DBF $text -- текст из DBF в cp866

    Возращаем удобоваримый и читаемый текст

AUTHOR

Daniil Popov <popov.daniil@gmail.com>

COPYRIGHT AND LICENSE

This software is copyright (c) 2017 by Daniil Popov.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.