我应该使用什么时候处理一个值在c#,这是一个SQL Server数据库的大int ?
当前回答
int(64)或long Datatype等价于BigInt。
其他回答
您可以使用长类型或Int64
Int64直接映射到BigInt。
源
使用长数据类型。
我认为等效的是Int64
我刚刚有一个脚本,返回一个插入的主键,并使用
SELECT @@identity
在我的bigint主键,我得到一个转换错误使用长-这就是为什么我开始这个搜索。至少在我的例子中,正确的答案是选择返回的类型是NUMERIC,这相当于一个十进制类型。使用long类型会导致强制转换异常。
这就是为什么要在不止一个谷歌搜索(甚至Stack Overflow!)中检查你的答案。
引用一位帮助过我的数据库管理员的话:
... BigInt和INT64是不一样的,不管它们看起来有多相似。部分原因是SQL经常将Int/BigInt转换为Numeric作为正常处理的一部分。所以当它转到OLE或。net时,所需的转换是NUMERIC到INT。 我们通常不会注意到,因为打印的值看起来是一样的。
推荐文章
- 在SQL server查询中将NULL替换为0
- Linq-to-Entities Join vs GroupJoin
- 在SQL中修改表的模式名
- 为什么字符串类型的默认值是null而不是空字符串?
- 在list中获取不同值的列表
- 组合框:向项目添加文本和值(无绑定源)
- 如何得到累计和
- 如何在SQL Server 2005的一条语句中更新两个表?
- AutoMapper:“忽略剩下的?”
- 如何为ASP.net/C#应用程序配置文件值中的值添加&号
- 从System.Drawing.Bitmap中加载WPF BitmapImage
- 如何找出一个文件存在于c# / .NET?
- 为什么更快地检查字典是否包含键,而不是捕捉异常,以防它不?
- 如何创建临时表与SELECT * INTO tempTable从CTE查询
- [DataContract]的命名空间