分享

[SQLServer] 在查询语句中将整数转为IP字符串(mssql2012

 观天落子 2013-06-20

[SQLServer] 在查询语句中将整数转为IP字符串

数据表的结构是——

CREATE TABLE [dbo].[ac_mainctls_new] (

 [id] [int] NULL ,

 [ctlip] [bigint] NULL ,

 [ctlname] [char] (30) COLLATE Chinese_PRC_CI_AS NULL ,

)

 

其中ctlip是设备的IP地址,以整数方式存储。

虽然可以用程序将整数转为IP字符串,但多了一道工序有点麻烦。于是我想直接在SQL查询语句中将其转为IP字符串。

 

 

经过思索与调试,我完成了该查询语句——

SELECT CAST(ctlip / 0x1000000 AS varchar(3)) 
+ '.' + CAST(ctlip / 0x10000 % 0x100 AS varchar(3))
+ '.' + CAST(ctlip / 0x100 % 0x100 AS varchar(3))
+ '.' + CAST(ctlip % 0x100 AS varchar(3)) AS ipstr, *
FROM ac_mainctls_new


 

查询结果为——

ipstr	ctlip
192.168.10.32	3232238112
192.168.10.35	3232238115
192.168.10.21	3232238101
192.168.10.19	3232238099

 

验证通过。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多