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

如何查询一个确定的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详情

运行结果

最新文章

  1. psoc学习
  2. CoreDataManager-OC版-兼容iOS10以前的版本
  3. android:installLocation = "auto" 的用法
  4. HttpRequest重写,解决资源战胜/链接超时/分块下载事件通知 问题。
  5. css3照片墙+曲线阴影
  6. EditText提示文字
  7. B. Quasi Binary
  8. 轻奢当道业绩逆势增长 Kate Spade联手韩国衣恋开拓中国市场_商场报道_中国时尚品牌网
  9. 浙大 pat 1047题解
  10. Entity Framework 新手入门友好实例
  11. grok 匹配log4j
  12. request.getParameter()及解决数据库中文乱码问题——实习第七天
  13. IGP和BGP路由协议配合降低非核心路由器的路由容量的实验与总结
  14. mysql有多大内存?能存多少数据?
  15. stack-protector-strong
  16. Linux聚合网络
  17. opencv批量读取图片
  18. Spring之jdbcTemplate实现orm
  19. json解析为泛型对象
  20. 李洪强iOS开发之静态库的打包一

热门文章

  1. HTML - 列表标签相关
  2. js '' ""的嵌套使用
  3. SPOJ 1043 GSS1 - Can you answer these queries I
  4. android 头像选择以及裁剪
  5. 菜鸟nginx源码剖析数据结构篇(十一) 共享内存ngx_shm_t[转]
  6. mysql limit 偏移量过大效率解决方式 转贴
  7. python基础数据类型初始,用户交互
  8. HDU--2602(0-1背包)
  9. 05-1-操作css样式
  10. 2018-12-6-Roslyn-如何基于-Microsoft.NET.Sdk-制作源代码包