首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >T-SQL中INT的二进制字符串

T-SQL中INT的二进制字符串
EN

Stack Overflow用户
提问于 2021-04-28 01:27:36
回答 1查看 99关注 0票数 0

我有7位二进制数据作为varchar存储在SQL Server数据库中。这个7位的二进制数据最终需要转换成一个int。我试图获取这个二进制字符串,然后将其转换为varbinary,然后再转换为整数。对varbinary的强制转换可以接受十六进制字符串,但是我无法找到这种强制转换接受二进制字符串的方法。

示例字符串:

代码语言:javascript
复制
0000010
0000100
0001001

这些应转换为:

代码语言:javascript
复制
2
4
9

我可以创建一个CLR函数来调用C#函数,但我希望用T-SQL完成这一切。

EN

回答 1

Stack Overflow用户

发布于 2021-04-28 02:31:53

手动转换

代码语言:javascript
复制
select id, sum(cast(substring(str, 7-p.pos, 1) as int) * power(2, p.pos)) val
from (
  SELECT 1 id, '0001001' str union all
  SELECT 2 id, '0001011' str
) t
cross apply (
  values 
     (0)
    ,(1)
    ,(2)
    ,(3)
    ,(4)
    ,(5)
    ,(6)
  ) p(pos)
group by id
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67287906

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档