數(shù)據(jù)表的結(jié)構(gòu)是——
CREATE TABLE [dbo].[ac_mainctls_new] (
[id] [int] NULL ,
[ctlip] [bigint] NULL ,
[ctlname] [char] (30) COLLATE Chinese_PRC_CI_AS NULL ,
)
其中ctlip是設(shè)備的IP地址,以整數(shù)方式存儲。
雖然可以用程序?qū)⒄麛?shù)轉(zhuǎn)為IP字符串,但多了一道工序有點麻煩。于是我想直接在SQL查詢語句中將其轉(zhuǎn)為IP字符串。
經(jīng)過思索與調(diào)試,我完成了該查詢語句——
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
查詢結(jié)果為——
ipstr ctlip192.168.10.32 3232238112192.168.10.35 3232238115192.168.10.21 3232238101192.168.10.19 3232238099
驗證通過。