Mysql存储IP地址

  1. 使用MySQL函数
  • MySQL函数

    inet_aton : 将IP转为整型
    inet_ntoa : 将整型转为IP

    • 建表
    CREATE TABLE `testip` (
    `IP`  bigint(10) NULL 
    )
    
    • 插入语句
    INSERT INTO testip (IP) VALUES (INET_ATON('255.255.255.255'))
    
    IP
    4294967295
    • 查看语句
    SELECT INET_NTOA(IP) IP FROM testip
    
    IP
    255.255.255.255
    • 错误
      Out of range value for column 'IP' at row 1
      将IP的字段类型改为 bigint
  1. 使用PHP函数

    • php函数 ip2long() 将IPV4地址转为数字格式
    • PHP函数 long2ip() 将数组格式转为IP地址类型
    $ip = '172.28.0.122';
    $iplong = sprintf('%u',ip2long($ip));
    echo $iplong.PHP_EOL;//2887516282
    echo long2ip($iplong);//172.28.0.122
    

    直接使用ip2long()函数会出现转换后为负数的情况(IP较大),使用%u来格式化为无符号整型。

  2. 链接
    MySQL存储IPv4的方式:https://www.cnblogs.com/phpper/p/10220703.html
    ip2long转换后为负数:https://www.cnblogs.com/phpper/p/10220302.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值