【mysql】ipv4地址转换为4字节整数

有时须要记录ipv4地址到数据库,直接保存字符varchar(15)可能有些浪费,若是直接保存一个整数的话性价比会更好一些,ipv4有4段,每段取值范围都是0~255,使用1个字节就能够保存,若是转换为一个整数4个字节就能够搞定,注意mysql需使用无符号int。

图片

注意在java中Integer是有符号的,最大值为2147483647,因此须要Long来盛放转换后的整数;位移运算优先级低于加法运算,位移处加了括号:java

public static Long getIpNum(final String ip) {
   Long ipNum = 0L;
   final String[] ipStr = ip.trim().split("\\.");
   for (final String str : ipStr) {
       ipNum = (ipNum << 8) + Integer.parseInt(str);
   }
   return ipNum;
}
同时mysql也提供了相关函数,能够方便进行转换:
select INET_ATON('255.255.255.255');-- 4294967295
select INET_NTOA(4294967295);-- 255.255.255.255

本文代码出发点是考虑包括两个极端的状况,即0.0.0.0~255.255.255.255,因此代码中使用Long类型,Long类型占用8字节,而数据库支持无符号整型,4字节就能够保存。由整数转为ipv4地址能够直接使用mysql的函数,也能够在代码中使用右移操做取出每一个字节所表明的的整数,而后拼接"."。mysql

相关文章
相关标签/搜索