zoukankan      html  css  js  c++  java
  • SQL Server:将6字节的十六进制页面号转化成【文件号:页面号】格式函数



        有时候我们需要知道存储在表中某条记录的所属文件号以及页面编号,但是经过我们自己查询,查询出来是一个十六进制页面号,那么我们怎么才能根据该十六进制页面号计算出该记录所对的“所属文件号”以及“页面编号”呢?
        以下的函数就能帮我们解决该问题:返回【x:xx】格式
           
    ALTER FUNCTION convert_page_nums(@page_num binary(6))
    RETURNS VARCHAR(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--------------------------
  • 相关阅读:
    《算法竞赛进阶指南》0x42树状数组 楼兰图腾
    《算法竞赛进阶指南》0x41并查集 奇偶游戏
    .NET技术-常规操作
    TFS-在windows上配置自动化部署
    * 常用软件下载
    Docker 修改网桥网段
    Docker
    Docker
    NETCORE
    .NET框架
  • 原文地址:https://www.cnblogs.com/xbf321/p/1565291.html
Copyright © 2011-2022 走看看