Выберите строки, где столбец соответствует любому IP-адресу в массиве inet [] - PullRequest
0 голосов
/ 28 апреля 2019

Я пытаюсь отобразить строки, которые имеют хотя бы одно значение в столбце типа inet[].

Я действительно не знаю ничего лучше, так что, кажется, было бы проще использовать что-то вроде этого, но он возвращает результаты с {}, который, я думаю, равен null в соответствии с типом inet[], но не с точки зрения is not null запроса?

peering_manager=# select asn,name,potential_internet_exchange_peering_sessions from peering_autonomoussystem where potential_internet_exchange_peering_sessions is not null order by potential_internet_exchange_peering_sessions limit 1;
 asn  |              name               | potential_internet_exchange_peering_sessions
------+---------------------------------+----------------------------------------------
 6128 | Cablevision Systems Corporation | {}
(1 row)

peering_manager=#

Поэтому, пытаясь немного углубиться в это, я думаю, может быть, если я попытаюсь сопоставить существование любого действительного IP-адреса в столбце inet[], это сработает, однако я получаю сообщение об ошибке и не понимаю Не понимаю, что он имеет в виду или как решить, чтобы достичь желаемых результатов:

peering_manager=# select asn,name,potential_internet_exchange_peering_sessions from peering_autonomoussystem where potential_internet_exchange_peering_sessions << inet '0.0.0.0/0';
ERROR:  operator does not exist: inet[] << inet
LINE 1: ...here potential_internet_exchange_peering_sessions << inet '0...
                                                             ^
HINT:  No operator matches the given name and argument type(s). You might need to add explicit type casts.
peering_manager=#

Возможно, это говорит о том, что оператор << недопустим для типа inet[] или что оператор << является недопустимой операцией при попытке запроса типа inet из значения, хранящегося как тип inet[] ? Или что-то еще?

В любом случае, я немного потерян. Может быть, есть лучший способ сделать это?

Вот таблица и пример набора данных, с которым я работаю.

peering_manager=# \d peering_autonomoussystem;
                                                     Table "public.peering_autonomoussystem"
                    Column                    |           Type           |                               Modifiers
----------------------------------------------+--------------------------+-----------------------------------------------------------------------
 id                                           | integer                  | not null default nextval('peering_autonomoussystem_id_seq'::regclass)
 asn                                          | bigint                   | not null
 name                                         | character varying(128)   | not null
 comment                                      | text                     | not null
 ipv6_max_prefixes                            | integer                  | not null
 ipv4_max_prefixes                            | integer                  | not null
 updated                                      | timestamp with time zone |
 irr_as_set                                   | character varying(255)   |
 ipv4_max_prefixes_peeringdb_sync             | boolean                  | not null
 ipv6_max_prefixes_peeringdb_sync             | boolean                  | not null
 irr_as_set_peeringdb_sync                    | boolean                  | not null
 created                                      | timestamp with time zone |
 potential_internet_exchange_peering_sessions | inet[]                   | not null
 contact_email                                | character varying(254)   | not null
 contact_name                                 | character varying(50)    | not null
 contact_phone                                | character varying(20)    | not null
Indexes:
    "peering_autonomoussystem_pkey" PRIMARY KEY, btree (id)
    "peering_autonomoussystem_asn_ec0373c4_uniq" UNIQUE CONSTRAINT, btree (asn)
Check constraints:
    "peering_autonomoussystem_ipv4_max_prefixes_check" CHECK (ipv4_max_prefixes >= 0)
    "peering_autonomoussystem_ipv6_max_prefixes_check" CHECK (ipv6_max_prefixes >= 0)
Referenced by:
    TABLE "peering_directpeeringsession" CONSTRAINT "peering_directpeerin_autonomous_system_id_691dbc97_fk_peering_a" FOREIGN KEY (autonomous_system_id) REFERENCES peering_autonomoussystem(id) DEFERRABLE INITIALLY DEFERRED
    TABLE "peering_internetexchangepeeringsession" CONSTRAINT "peering_peeringsessi_autonomous_system_id_9ffc404f_fk_peering_a" FOREIGN KEY (autonomous_system_id) REFERENCES peering_autonomoussystem(id) DEFERRABLE INITIALLY DEFERRED

peering_manager=#
peering_manager=# select asn,name,potential_internet_exchange_peering_sessions from peering_autonomoussystem limit 7;
  asn  |              name               |                                                                 potential_internet_exchange_peering_sessions
-------+---------------------------------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
 37662 | WIOCC                           | {2001:504:1::a503:7662:1,198.32.160.70}
 38001 | NewMedia Express Pte Ltd        | {2001:504:16::9471,206.81.81.204}
 46562 | Total Server Solutions          | {2001:504:1::a504:6562:1,198.32.160.12,2001:504:16::b5e2,206.81.81.81,2001:504:1a::35:21,206.108.35.21,2001:504:2d::18:80,198.179.18.80,2001:504:36::b5e2:0:1,206.82.104.156}
 55081 | 24Shells Inc                    | {2001:504:1::a505:5081:1,198.32.160.135}
 62887 | Whitesky Communications         | {2001:504:16::f5a7,206.81.81.209}
  2603 | NORDUnet                        | {2001:504:1::a500:2603:1,198.32.160.21}
  6128 | Cablevision Systems Corporation | {}
(7 rows)

Ответы [ 2 ]

1 голос
/ 28 апреля 2019

Вы можете использовать array_length(). Для пустых массивов или нулей это возвращает NULL.

...
WHERE array_length(potential_internet_exchange_peering_sessions, 1) IS NOT NULL
...
0 голосов
/ 28 апреля 2019

лучше сравнивать длину массива с целым числом

...
WHERE array_length(potential_internet_exchange_peering_sessions, 1) > 0
...
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...