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)
    
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容