在 SQL Server 中从整数转换为二进制并返回

Converting from integer to binary and back in SQL Server(在 SQL Server 中从整数转换为二进制并返回)
本文介绍了在 SQL Server 中从整数转换为二进制并返回的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我整个上午都在用这个头撞墙.

I've been banging my head against the wall with this one all morning.

以下 SQL 代码及其结果对我来说毫无意义:

The following SQL code and its' result makes no sense to me:

select CONVERT(INT, CONVERT(BINARY(30),2691485888))

导致:

-1060082528

什么?为什么结果不等于我原来的整数?

What? Why doesn't the result equal my original integer?

我的整个目标是将一个整数转换为字节并将这些字节存储到数据库中,但是没有让这个基本示例工作,我被卡住了.谁能解释一下我做错了什么?

My whole objective is to convert an integer into bytes and store those bytes into the database, but without getting this basic example to work I am stuck. Can anyone explain what I'm doing wrong?

顺便说一下,我使用的是 Sql Server 2005 (9.0.4340)

By the way, I am using Sql Server 2005 (9.0.4340)

推荐答案

正如我在之前的评论中所指出的,2,691,485,888 比 INT 可以容纳的要大.

As I noted in my earlier comment, 2,691,485,888 is larger than what an INT can hold.

这会起作用:

select CONVERT(BIGINT, CONVERT(BINARY(30), CONVERT(BIGINT, 2691485888)))

这篇关于在 SQL Server 中从整数转换为二进制并返回的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Execute complex raw SQL query in EF6(在EF6中执行复杂的原始SQL查询)
Hibernate reactive No Vert.x context active in aws rds(AWS RDS中的休眠反应性非Vert.x上下文处于活动状态)
Bulk insert with mysql2 and NodeJs throws 500(使用mysql2和NodeJS的大容量插入抛出500)
Flask + PyMySQL giving error no attribute #39;settimeout#39;(FlASK+PyMySQL给出错误,没有属性#39;setTimeout#39;)
auto_increment column for a group of rows?(一组行的AUTO_INCREMENT列?)
Sort by ID DESC(按ID代码排序)