Mysql怎样存储IP地址

Mysql怎样存储IP地址


概述

在Mysql中并没有提供针对IP地址存储的数据格式,在开发中我们可以选择使用char、varchar、int来存储,根据mysql字段类型选择的规则:字段类型定义使用最合适(最小)、最简单的数据类型,优先选择使用int类型来存储,其在逻辑运算上也要比char、varchar更快

int类型存储IP地址

在Mysql中提供了两个函数,用来把IP地址与数字类型的相互转化

  • inet_aton():把IP地址转化为数字

    这种算法其实借用了国际上对各国IP地址的区分中使用的ip number。
    a.b.c.d 的ip number是:
    a * 256的3次方 + b * 256的2次方 + c * 256的1次方 + d * 256的0次方。

    mysql> select inet_aton('255.255.255.255');
    +------------------------------+
    | inet_aton('255.255.255.255') |
    +------------------------------+
    |                   4294967295 |
    +------------------------------+
    1 row in set (0.00 sec)
    
  • inet_ntoa():把数字转化成IP地址

    mysql> select inet_ntoa(4294967295);
    +-----------------------+
    | inet_ntoa(4294967295) |
    +-----------------------+
    | 255.255.255.255       |
    +-----------------------+
    1 row in set (0.00 sec)
    

你可能感兴趣的:(Mysql怎样存储IP地址)