mysql:把IP存进数字类型的字段——查询提速优化

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优化的范畴。平时多注意点积累。                                                                                 

                             

相关其他文章:

tomcat把本地Windows路径的文件设置成服务访问路径

Map——java基础教程

微信公众平台少于300字怎么申请原创?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值