1.在java后端把ip字符串转成long类型的处理工具方法:
public static long ip2long(String ip) {
String[] p = ip.split("\\.");
if (p.length != 4)
return 0;
int p1 = ((Integer.valueOf(p[0]) << 24) & 0xFF000000);
int p2 = ((Integer.valueOf(p[1]) << 16) & 0x00FF0000);
int p3 = ((Integer.valueOf(p[2]) << 8) & 0x0000FF00);
int p4 = ((Integer.valueOf(p[3]) << 0) & 0x000000FF);
return ((p1 | p2 | p3 | p4) & 0xFFFFFFFFL);
}
2.在java后端把long类型转成ip字符串的处理工具方法:
public static String long2ip(long ip) {
StringBuilder sb = new StringBuilder();
sb.append((ip >> 24) & 0xFF).append('.').append((ip >> 16) & 0xFF).append('.').append((ip >> 8) & 0xFF)
.append('.').append((ip >> 0) & 0xFF);
return sb.toString();
}
3.mysql数据库将IP地址转换为整型:
inet_aton(ip地址)
如:
SELECT INET_ATON('192.168.1.38'); -- 3232235814
4.mysql数据库将整型转换为IP地址
inet_ntoa(数字类型的ip)
如:
SELECT INET_NTOA(3232235814) -- 192.168.1.38
5.为什么把IP转成数字类型的存库?
优点:提高查询速度。这属于sql优化的范畴。平时多注意点积累。
相关其他文章: