mysql提供了兩個方法來處理ip地址: 插入數據前,先用inet_aton把ip地址轉為整型,可以節省空間。 顯示數據時,使用inet_ntoa把整型的ip地址轉為電地址顯示即可。為社麽這樣存?,性能上的提示比直接存儲字元串的IP要高出很多。示例: 插入幾條數據: 查詢顯示地址: 如果需要找出在某 ...
mysql提供了兩個方法來處理ip地址:
inet_aton 把ip轉為無符號整型(4-8位)
inet_ntoa 把整型的ip轉為電地址
插入數據前,先用inet_aton把ip地址轉為整型,可以節省空間。
顯示數據時,使用inet_ntoa把整型的ip地址轉為電地址顯示即可。為社麽這樣存?,性能上的提示比直接存儲字元串的IP要高出很多。
示例:
CREATE TABLE `t_user` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(15) DEFAULT NULL COMMENT '用戶名', `ip` bigint(20) DEFAULT NULL COMMENT 'IP地址', PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;
插入幾條數據:
INSERT INTO `t_user` ( `id`, `name`, `ip` ) VALUES ( 2, 'babala', inet_aton( '127.0.0.1' ) ), ( 3, 'maly', inet_aton( '192.168.1.1' ) ), ( 4, 'kaven', inet_aton( '111.175.7.143' ) );
查詢顯示地址:
select id,name,inet_ntoa(ip) as ip from `t_user`;
如果需要找出在某個網段的用戶(例如:192.168.1.1 ~ 192.168.1.100),可以利用php的ip2long方法,把ip地址轉為整型,再進行比較。
$ip_start = '192.168.1.1'; $ip_end = '192.168.1.100'; echo sprintf('%u',ip2long($ip_start)).PHP_EOL; // 3232235777 echo sprintf('%u',ip2long($ip_end)).PHP_EOL; // 3232235876