mysql 存儲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

總結
1.保存ip地址到數據庫,使用unsigned int格式,插入時使用inet_aton方法把ip先轉為無符號整型,可以節省存儲空間。 
2.顯示時使用inet_ntoa把整型ip地址轉為電地址。 
3.php 使用 ip2long轉ip為整型時,需要注意出現負數的問題(如果出現負數:參照之前我寫的這篇


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM