SQL Server:将6字节的十六进制页面号转化成【文件号:页面号】格式函数




有时候我们需要知道存储在表中某条记录的所属文件号以及页面编号,但是经过我们自己查询,查询出来是一个十六进制页面号,那么我们怎么才能根据该十六进制页面号计算出该记录所对的“所属文件号”以及“页面编号”呢?
以下的函数就能帮我们解决该问题:返回【x:xx】格式

ALTERFUNCTIONconvert_page_nums(@page_numbinary(6))
RETURNSVARCHAR(11)
AS
BEGIN
RETURN(
CONVERT(VARCHAR(2),(
CONVERT(INT,SUBSTRING(@page_num,6,1))*POWER(2,8)
)
+
(
CONVERT(INT,SUBSTRING(@page_num,5,1)))
)
+':'+
CONVERT(VARCHAR(11),
(
CONVERT(INT,SUBSTRING(@page_num,4,1))*POWER(2,24))+
(
CONVERT(INT,SUBSTRING(@page_num,3,1))*POWER(2,16))+
(
CONVERT(INT,SUBSTRING(@page_num,2,1))*POWER(2,8))+
(
CONVERT(INT,SUBSTRING(@page_num,1,1)))
)
)
END 随后可以执行如下的SELECT 语句来调用该函数
SELECT dbo.convert_page_nums(0x6E0000000100);

那么就会得到以下结果:1:110

----------------------END--------------------------
优质内容筛选与推荐>>
1、每个程序员都应该经历一次软考 - 南京.王清培 - 博客园
2、冲刺会议第四天
3、MediaPlayer类——播放视频和音乐
4、**80. Remove Duplicates from Sorted Array II 删除排序数组中的重复项 II
5、--@angularJS--独立作用域scope绑定策略之=符策略


长按二维码向我转账

受苹果公司新规定影响,微信 iOS 版的赞赏功能被关闭,可通过二维码转账支持公众号。

    阅读
    好看
    已推荐到看一看
    你的朋友可以在“发现”-“看一看”看到你认为好看的文章。
    已取消,“好看”想法已同步删除
    已推荐到看一看 和朋友分享想法
    最多200字,当前共 发送

    已发送

    朋友将在看一看看到

    确定
    分享你的想法...
    取消

    分享想法到看一看

    确定
    最多200字,当前共

    发送中

    网络异常,请稍后重试

    微信扫一扫
    关注该公众号