org.postgresql.util.PSQLException: ОШИБКА: неверный синтаксис ввода для типа inet: - PullRequest
0 голосов
/ 16 марта 2012

Я пытаюсь вставить ipaddress в таблицу Postgres из проекта Java.

String ipIns = "INSERT INTO trusted_domains(id, from_ip, to_ip) VALUES (?, ?, ?);";
pstmt = conn.prepareStatement(ipIns);
pstmt.setInt(1, Integer.parseInt(id));
pstmt.setObject(2, InetAddress.getByName(fromIP));
pstmt.setObject(3, InetAddress.getByName(toIP));
pstmt.execute();

Я получаю исключение для этого оператора pstmt.setObject (2, InetAddress.getByName (fromIP));

org.postgresql.util.PSQLException: ОШИБКА: неверный синтаксис ввода для типа inet:

Пожалуйста, помогите мне в этом исключении

Спасибо --SD

1 Ответ

1 голос
/ 17 марта 2012

Вы уже нашли его, но для широкой публики:

Тип данных inet принимает IPv4 и IPv6 хосты и сети, а не доменные имена.
Работает:

SELECT '192.168.1.251'::inet
SELECT '123.45.67.89/32'::inet
SELECT '::ffff:10.4.3.2'::inet
SELECT '1234:ef8:345:ad:934:efff:aaa:d1f1/128'::inet

Не работает:

SELECT 'stackoverflow.com'::inet
...