mysql hibernate 查询ip地址在mysql的网段

买的数据库,地址是字符串格式

如何查询一个确定的ip在哪里呢?

直接通过字符串查询估计要慢死了

可以先把自己的要查询的ip转换为数字,然后再去以数字的方式查询

IP转数字1.2.6.0转为数字

SELECT INET_ATON('1.2.6.0');

 

 插一句,数字转ip 

SELECT INET_NTOA(16909824);

 

 

 整型字段的比较比字符串效率高很多,这也符合一项优化原则:字段类型定义使用最合适(最小),最简单的数据类型。
inet_aton()算法,其实借用了国际上对各国IP地址的区分中使用的ip number。
a.b.c.d 的ip number是:
a * 256的3次方 + b * 256的2次方 + c * 256的1次方 + d * 256的0次方。

这一点有点像hex转10进制的位权的概念

然后用between and查询就行了,但是速度好像比较慢啊

SELECT * FROM t_ip WHERE 16909824 BETWEEN ip_start_num AND ip_end_num;

 

不知道有什么好办法解决

不过对于hibernate无法直接使用这个函数,

所以需要自己手动的计算一下ip转换后的数字

long ip_L
                    = Integer.parseInt(ipArray[0]) * 16777216 //256的3次方
                    + Integer.parseInt(ipArray[1]) * 65536//256的2次方
                    + Integer.parseInt(ipArray[2]) * 256//256的1次方
                    + Integer.parseInt(ipArray[3]) * 1;//256的0次方
            ipModel = cid.getDetialByIpL(ip_L);  //查询ip详情

 运行结果

 

posted @ 2018-12-17 16:20  不打鱼光晒网  阅读(557)  评论(0编辑  收藏  举报