竹笋

首页 » 问答 » 灌水 » mysqlipv4地址转换为4字节整
TUhjnbcbe - 2022/10/25 11:51:00
北京中科医院几级 https://mip.yyk.99.com.cn/fengtai/68389/zuozhen.html

有时需要记录ipv4地址到数据库,直接保存字符varchar(15)可能有些浪费,如果直接保存一个整数的话性价比会更好一些,ipv4有4段,每段取值范围都是0~,使用1个字节就可以保存,如果转换为一个整数4个字节就可以搞定,注意mysql需使用无符号int。

注意在java中Integer是有符号的,最大值为,所以需要Long来盛放转换后的整数;位移运算优先级低于加法运算,位移处加了括号:

同时mysql也提供了相关函数,可以方便进行转换:

本文代码出发点是考虑包括两个极端的情况,即0.0.0.0~...,所以代码中使用Long类型,Long类型占用8字节,而数据库支持无符号整型,4字节就可以保存。由整数转为ipv4地址可以直接使用mysql的函数,也可以在代码中使用右移操作取出每个字节所代表的的整数,然后拼接“.”。

1
查看完整版本: mysqlipv4地址转换为4字节整