函数名:INET_ATON(EXPR)
函数功能:给出一个作为字符串的网络地址,返回一个代表地址数值的整数。’
函数名:INET_NTOA(EXPR)
函数功能:给定一个数字网络地址,返回作为字符串的该地址的电地址表示。
首先我们要清楚为什么要进行转换。。。有什么好处?
优点如下:
当前很多应用都是用字符串char(15)来存储IP地址(占16个字节),利用INET_ATON()和INET_NTOA()函数,来存储IP地址和INT值之间的转化,只需要4个字节,节省了存储空间,同时效率也高很多。
方便操作,比如判等,hash。尤其在各种防火墙规则过滤算法中有很大作用。
本次主要调查的是INET_ATON(EXPR): 将IP地址格式定义为(A.B.C.D)转化后INT数值计算方式为:A*2^24+B*2^16+C*2^8+D
下面是几个例子:
mysql> SELECT inet_aton('1.1.1.1');
+----------------------+
| inet_aton('1.1.1.1') |
+----------------------+
| 16843009 |
+----------------------+
1 row in set (0.00 sec)
结果:1*2^24+1*2^16+1*2^8+1=16843009
---------------临界值的测试
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('255.255.255.256');
+------------------------------+
| inet_aton('255.255.255.256') |
+------------------------------+
| NULL |
+------------------------------+
---------------非法输入
mysql> select inet_aton('0.1.1.1.1');
+------------------------+
| inet_aton('0.1.1.1.1') |
+------------------------+
| 16843009 |
+------------------------+
1 row in set (0.00 sec)
mysql> select inet_aton('0.1.1.1.1.9.7.7');
+------------------------------+
| inet_aton('0.1.1.1.1.9.7.7') |
+------------------------------+
| 282578800674567 |
+------------------------------+
1 row in set (0.00 sec)
由select inet_aton('255.255.255.256');得出的结果知道:IP转化为INT最大值为4294967295。
这两个非法输入没有报错。。。
这是MYSQL出现的一个BUG。不过有可能是我的版本太低吧。。。
[admin@sg620g18 ~]$ mysql -V
mysql Ver 14.14 Distrib 5.1.52, for redhat-linux-gnu (x86_64) using readline 5.1
这是我的版本。。。
谢谢大家刚开始写,多多指教。