mysql hibernate 查询ip地址在mysql的网段
2024-09-01 18:55:12
买的数据库,地址是字符串格式
如何查询一个确定的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详情
运行结果
最新文章
- psoc学习
- CoreDataManager-OC版-兼容iOS10以前的版本
- android:installLocation = ";auto"; 的用法
- HttpRequest重写,解决资源战胜/链接超时/分块下载事件通知 问题。
- css3照片墙+曲线阴影
- EditText提示文字
- B. Quasi Binary
- 轻奢当道业绩逆势增长 Kate Spade联手韩国衣恋开拓中国市场_商场报道_中国时尚品牌网
- 浙大 pat 1047题解
- Entity Framework 新手入门友好实例
- grok 匹配log4j
- request.getParameter()及解决数据库中文乱码问题——实习第七天
- IGP和BGP路由协议配合降低非核心路由器的路由容量的实验与总结
- mysql有多大内存?能存多少数据?
- stack-protector-strong
- Linux聚合网络
- opencv批量读取图片
- Spring之jdbcTemplate实现orm
- json解析为泛型对象
- 李洪强iOS开发之静态库的打包一
热门文章
- HTML - 列表标签相关
- js '' ";";的嵌套使用
- SPOJ 1043 GSS1 - Can you answer these queries I
- android 头像选择以及裁剪
- 菜鸟nginx源码剖析数据结构篇(十一) 共享内存ngx_shm_t[转]
- mysql limit 偏移量过大效率解决方式 转贴
- python基础数据类型初始,用户交互
- HDU--2602(0-1背包)
- 05-1-操作css样式
- 2018-12-6-Roslyn-如何基于-Microsoft.NET.Sdk-制作源代码包