如果你在MSSQLServer中有一个浮点数,你在.NET中映射这个是什么?
你能把它转换成双倍还是会丢失数字?
SQLServer float
和C#/ VB double
具有相同的表示形式.这是正确的映射.您不想做的是将SQL Server映射float
到C#/ VB,float
因为这可能会导致精度损失.SQL Server real
映射到C#/ VB float
.
可以在MSDN上找到T-SQL浮点数和实数类型定义.C#双重定义也可以在MSDN中找到,浮点定义也可以.
查看:
SQL Server数据类型及其.NET Framework等效项(msdn),可全面参考SQL Server和.Net之间的数据类型映射
在您的情况下,SQL Server本机类型float映射到SQL Server CLR SqlDouble,然后是.Net中的Double
更新(2016年5月):
msdn文档的更新版本:映射CRL参数数据