MYSQL中INET_ATON(expr)函数的调查

函数名: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

这是我的版本。。。

谢谢大家刚开始写,多多指教。

你可能感兴趣的:(Mysql)