mysql怎么知道自己的网段_mysql hibernate 查询ip地址在mysql的网段

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

73eae950bfb61e5f3c4206bfefcf7632.png

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

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

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

IP转数字1.2.6.0转为数字

SELECT INET_ATON('1.2.6.0');

838d6ca4cafdb074f5d87bd02aaac4c6.png

插一句,数字转ip

SELECT INET_NTOA(16909824);

ebaa2361324dc0499d815c4e34caa21c.png

整型字段的比较比字符串效率高很多,这也符合一项优化原则:字段类型定义使用最合适(最小),最简单的数据类型。

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;

1535b0495230736a53d6f440f0479c50.png

不知道有什么好办法解决

cb3758a86b3dce96ce145ad10bc11273.png

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

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

longip_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详情

运行结果

2490f576f98abb92387a46f6c543a27a.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值