メインコンテンツまでスキップ

IS_IPV4_COMPAT

is_ipv4_compat

説明

IPv6アドレスがIPv4互換アドレスかどうかを確認します。IPv4互換アドレスは、IPv6ネットワークでIPv4アドレスを表現するために使用される特別なIPv6アドレス形式です。

構文

IS_IPV4_COMPAT(<ipv6_address>)

パラメータ

  • <ipv6_address>: IPv6アドレスのバイナリ表現(VARCHAR型、16バイト)

戻り値

戻り値の型: TINYINT

戻り値の意味: 1はIPv4互換アドレスであることを示し、0はIPv4互換アドレスではないことを示す

使用上の注意

  • IPv4互換アドレスの形式は::IPv4で、最初の12バイトは0、最後の4バイトにIPv4アドレスが含まれる
  • 入力は16バイトのIPv6バイナリデータである必要がある
  • この形式はIPv6移行期間用にRFC 4291で定義されている
  • 最後の4バイトは0にできないため、::0.0.0.0は有効なIPv4互換アドレスではない。0.0.0.0はIPv4ユニキャストアドレスではなく、RFC 4291のIPv4-Mapped IPv6 Address定義を満たさないため
  • 入力パラメータがNULLの場合はNULLを返す

IPv4互換アドレスをチェックする。

SELECT is_ipv4_compat(INET6_ATON('::192.168.1.1')) as is_compat;
+-----------+
| is_compat |
+-----------+
| 1 |
+-----------+

非IPv4互換アドレスを確認します。

SELECT 
is_ipv4_compat(INET6_ATON('2001:db8::1')) as standard_ipv6,
is_ipv4_compat(INET6_ATON('::ffff:192.168.1.1')) as ipv4_mapped,
is_ipv4_compat(INET6_ATON('::0.0.0.0')) as zero_ip;
+--------------+------------+---------+
| standard_ipv6| ipv4_mapped| zero_ip |
+--------------+------------+---------+
| 0 | 0 | 0 |
+--------------+------------+---------+

境界値を確認してください。

SELECT 
is_ipv4_compat(INET6_ATON('::0.0.0.0')) as min_ip,
is_ipv4_compat(INET6_ATON('::255.255.255.255')) as max_ip;
+--------+--------+
| min_ip | max_ip |
+--------+--------+
| 0 | 1 |
+--------+--------+

入力パラメータがNULLの場合、NULLを返します。

SELECT is_ipv4_compat(NULL) as null_result;
+-------------+
| null_result |
+-------------+
| NULL |
+-------------+

キーワード

IS_IPV4_COMPAT