sql-server - sqflt8、sqlmoney 和其他原生 SQL 数据类型的二进制存储格式是什么?

标签 sql-server file-format bcp

根据文档,可以使用 native SQL Server 数据格式的 bcp 导入或导出 native (二进制)数据。这些示例包括 SQLFLT8、SQLFLT4、SQLMONEY 或 SQLNUMERIC。

有谁知道各种类型的数据格式是什么,或者可以在何处找到指定这些格式的文档。例如,SQLFLT8 是存储为 IEEE double 数还是其他格式?

编辑:来自 kevchadders 的回答和 Andrew我有一点顿悟,我在谷歌上搜索了一些 #define 和 typedef,看看我是否能找到带有定义的 C 头文件。这想出了一个文件 odbcdss.h ; answer我在下面发布了一些来自文件的内容,看起来很有希望。

最佳答案

我不确定这个理论是否成立,但是可以使用一些 SQL 和一些计算来找出类型的内部存储。我在我的博客上为新的 datetime2/datetimeoffset 做了这个,特别是为了获得内部二进制格式,因为我有兴趣看看它们是如何获得额外的准确性的。

以金钱为例

declare @test money
set @test = 12.34
select @test -- shows 12.34 as expected

declare @binaryValue binary(8)
set @binaryvalue = convert(binary(8),@test)
select @binaryvalue 

输出:0x000000000001E208

即 123400 当被视为十进制数时,钱被存储到 4 个小数位,因此将指示 12.3400 作为值,从理论上反转这一点,十六进制中的值仅为 1 应为 0.0001
declare @test money
declare @binaryValue binary(8)
set @binaryvalue = 0x0000000000000001
set @test = convert(money,@binaryvalue)
select @test

输出 0.0001

接下来我要检查的是负数,
declare @test money
set @test = -12.34
select @test -- shows -12.34 as expected

declare @binaryValue binary(8)
set @binaryvalue = convert(binary(8),@test)
select @binaryvalue 

输出:0xFFFFFFFFFFFE1DF8

所以看起来它是一个有符号的 8 字节数字,因为它刚刚从 FF 中取出了数字......等。快速检查 -0.0001 会按预期给出所有 0xFFF....FFF,-0.0002 按预期给出 0xFF....FFE。

我不确定这是否适用于 BCP,但作为内部存储格式,我会猜测一个有符号的 8 字节整数,假设有 4 个小数位。

关于sql-server - sqflt8、sqlmoney 和其他原生 SQL 数据类型的二进制存储格式是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2099919/

相关文章:

SQL 服务器 : can't select columns of one table by filtering from another table on same database issue

sql - 如何授予数据库所有者(DBO)EXTERNAL ACCESS ASSEMBLY权限?

python - python列表列表的用户可读文件格式

3d - 如何格式化 ParaView 的 PLOT3D 文件?

sql - 为什么bcp在列包含空字符串时输出null,在列为null时输出空字符串?

c# - 是否可以从 C# 创建 SQL Server native 文件(如 BCP native 格式)

sql-server - 从 dacpac 获取计算列的 DataType

sql-server - 逻辑应用执行 SQL TO JSON 自动对输出进行分块

Perforce:防止 Perforce 改变文本文件格式

sql - bcp 不会输出临时表