国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

mysql 使用inet_aton和inet_ntoa處理ip地址數據的實例

2024-07-24 13:12:56
字體:
來源:轉載
供稿:網友

本文將介紹如何在數據庫中使用合適格式保存ip地址數據,并能方便的對ip地址進行比較的方法。

1、保存ip地址到數據庫

數據庫中保存ip地址,字段一般會定義為:

`ip` char(15) NOT NULL,

因為ip地址(255.255.255.255)的最大長度是15,使用15位char已足夠。

創建表user

CREATE TABLE `user` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `name` varchar(30) NOT NULL, `ip` char(15) NOT NULL, PRIMARY KEY (`id`)) ENGINE=InnoDB;

插入幾條數據

INSERT INTO `user` (`id`, `name`, `ip`) VALUES(2, 'Abby', '192.168.1.1'),(3, 'Daisy', '172.16.11.66'),(4, 'Christine', '220.117.131.12');

2、mysql inet_aton 與 inet_ntoa 方法

mysql提供了兩個方法來處理ip地址

inet_aton 把ip轉為無符號整型(4-8位)

inet_ntoa 把整型的ip轉為電地址

插入數據前,先用inet_aton把ip地址轉為整型,可以節省空間,因為char(15) 占16字節。

顯示數據時,使用inet_ntoa把整型的ip地址轉為電地址顯示即可。

例子:

CREATE TABLE `user` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `name` varchar(100) NOT NULL, `ip` int(10) unsigned NOT NULL, PRIMARY KEY (`id`)) ENGINE=InnoDB;

插入幾條數據

INSERT INTO `user` (`id`, `name`, `ip`) VALUES(2, 'Abby', inet_aton('192.168.1.1')),(3, 'Daisy', inet_aton('172.16.11.66')),(4, 'Christine', inet_aton('220.117.131.12'));mysql> select * from `user`;+----+-----------+------------+| id | name  | ip   |+----+-----------+------------+| 2 | Abby  | 3232235777 || 3 | Daisy  | 2886732610 || 4 | Christine | 3698688780 |+----+-----------+------------+

查詢顯示為電地址

mysql> select id,name,inet_ntoa(ip) as ip from `user`;+----+-----------+----------------+| id | name  | ip    |+----+-----------+----------------+| 2 | Abby  | 192.168.1.1 || 3 | Daisy  | 172.16.11.66 || 4 | Christine | 220.117.131.12 |+----+-----------+----------------+

3、比較方法

如果需要找出在某個網段的用戶(例如:172.16.11.1 ~ 172.16.11.100),可以利用php的ip2long方法,把ip地址轉為整型,再進行比較。

<?php$ip_start = '172.16.11.1';$ip_end = '172.16.11.100';echo 'ip2long(ip_start):'.sprintf('%u',ip2long($ip_start)); // 2886732545echo 'ip2long(ip_end):'.sprintf('%u',ip2long($ip_end));  // 2886732644?>

查詢:

mysql> select ip,name,inet_ntoa(ip) as ip from `user` where ip>=2886732545 and ip<=2886732644;+------------+-------+---------------+| ip   | name | ip   |+------------+-------+---------------+| 2886732610 | Daisy | 172.16.11.66 |+------------+-------+---------------+

注意:使用ip2long方法把ip地址轉為整型時,對于大的ip會出現負數,出現原因及處理方法可以參考我另一篇文章:《詳談php ip2long 出現負數的原因及解決方法

4、總結

1、保存ip地址到數據庫,使用unsigned int格式,插入時使用inet_aton方法把ip先轉為無符號整型,可以節省存儲空間。

2、顯示時使用inet_ntoa把整型ip地址轉為電地址。

3、php ip2long轉ip為整型時,需要注意出現負數。

以上這篇mysql 使用inet_aton和inet_ntoa處理ip地址數據的實例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 屯留县| 寿阳县| 调兵山市| 平罗县| 桦甸市| 珠海市| 澜沧| 广州市| 洛川县| 乌恰县| 宁陕县| 南木林县| 临汾市| 延长县| 龙胜| 凤凰县| 江城| 于都县| 阳西县| 宜君县| 襄樊市| 大化| 夹江县| 西乌| 邳州市| 花垣县| 桂东县| 沈丘县| 邛崃市| 石渠县| 漳州市| 集贤县| 岢岚县| 台江县| 新和县| 静海县| 含山县| 新干县| 华宁县| 威宁| 平利县|