利用MySql内置函数对IP进行排序

INET_ATON(expr)


Given the dotted-quad representation of a network address as a string, returns an integer that represents the numeric value of the address. Addresses may be 4- or 8-byte addresses.


mysql> SELECT INET_ATON('209.207.224.40');
        -> 3520061480
The generated number is always in network byte order. For the example just shown, the number is calculated as 209×2563 + 207×2562 + 224×256 + 40.


INET_ATON() also understands short-form IP addresses:


mysql> SELECT INET_ATON('127.0.0.1'), INET_ATON('127.1');
        -> 2130706433, 2130706433
Note: When storing values generated by INET_ATON(), it is recommended that you use an INT UNSIGNED column. If you use a (signed) INT column, values corresponding to IP addresses for which the first octet is greater than 127 cannot be stored correctly. See Section 11.2, “Numeric Types”.


INET_NTOA(expr)


Given a numeric network address (4 or 8 byte), returns the dotted-quad representation of the address as a string.


mysql> SELECT INET_NTOA(3520061480);
        -> '209.207.224.40'


以上是Mysql手册中的说明,下面用实例来说明如何用这些函数进行排序




假设ip是以字符串形式存储在表table_device的device_ip字段中,则以下这句可以返回以ip排序的结果


select device_ip from table_device order by inet_aton(device_ip)


结果:


192.168.0.1


192.168.0.51


92.168.0.111


92.168.0.223
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值