程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> MySQL存儲IP地址的方法,mysql存儲ip

MySQL存儲IP地址的方法,mysql存儲ip

編輯:MySQL綜合教程

MySQL存儲IP地址的方法,mysql存儲ip


為什麼要問如何存儲IP?

首先就來闡明一下部分人得反問:為什麼要問IP得怎樣存,直接varchar類型不就得了嗎?

其實做任何程序設計都要在功能實現的基礎上最大限度的優化性能。而數據庫設計是程序設計中不可忽略的一個重要部分,所以巧存IP地址可以一定程度獲得很大提升。

利用函數算法處理

在MySQL中沒有直接提供IP類型字段,但如果有兩個函數可以把IP與最大長度為10位數字類型互轉,所以使用int類型存儲IP比varchar類型存儲IP地址性能要提升很多,減少不少空間。因為varchar是可變長形,需要多余的一個字節存儲長度。另外int型在邏輯運算上要比varchar速度快。

 
IP轉數字函數inet_aton()

我們轉換下幾個常用的IP地址

 mysql> select inet_aton('255.255.255.255');
 +------------------------------+
 | inet_aton('255.255.255.255') |
 +------------------------------+
 |          4294967295 |
 +------------------------------+
 1 row in set (0.00 sec)
  
 mysql> select inet_aton('192.168.1.1');  
 +--------------------------+
 | inet_aton('192.168.1.1') |
 +--------------------------+
 |        3232235777 |
 +--------------------------+
 1 row in set (0.00 sec)
  
 mysql> select inet_aton('10.10.10.10');
 +--------------------------+
 | inet_aton('10.10.10.10') |
 +--------------------------+
 |        168430090 |
 +--------------------------+
 1 row in set (0.00 sec)

所以IP的表字段可以設置為INT(10)就好,如果IP獲取不到可以直接存0代表獲取不到IP的意思

 

數字轉IP函數inet_ntoa()

 mysql> select inet_ntoa(4294967295);
 +-----------------------+
 | inet_ntoa(4294967295) |
 +-----------------------+
 | 255.255.255.255    |
 +-----------------------+
 1 row in set (0.00 sec)
 
 mysql> select inet_ntoa(3232235777);
 +-----------------------+
 | inet_ntoa(3232235777) |
 +-----------------------+
 | 192.168.1.1      |
 +-----------------------+
 1 row in set (0.00 sec)
 
 mysql> select inet_ntoa(168430090);
 +----------------------+
 | inet_ntoa(168430090) |
 +----------------------+
 | 10.10.10.10     |
 +----------------------+
 1 row in set (0.00 sec)
  
 mysql> select inet_ntoa(0);    
 +--------------+
 | inet_ntoa(0) |
 +--------------+
 | 0.0.0.0   |
 +--------------+
 1 row in set (0.00 sec)

注意,0轉換為 0.0.0.0

 整型字段的比較比字符串效率高很多,這也符合一項優化原則:字段類型定義使用最合適(最小),最簡單的數據類型。
inet_aton()算法,其實借用了國際上對各國IP地址的區分中使用的ip number。
a.b.c.d 的ip number是:
a * 256的3次方 + b * 256的2次方 + c * 256的1次方 + d * 256的0次方。

以上講解的就是MySQL存儲IP地址的方法,希望能夠對大家的學習有所幫助。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved