我应该使用什么时候处理一个值在c#,这是一个SQL Server数据库的大int ?
当前回答
如果你在你的数据库表中使用bigint,你可以在c#中使用Long
其他回答
我处理一个bigint数据类型显示在一个DataGridView,并使它像这样
something = (int)(Int64)data_reader[0];
我刚刚有一个脚本,返回一个插入的主键,并使用
SELECT @@identity
在我的bigint主键,我得到一个转换错误使用长-这就是为什么我开始这个搜索。至少在我的例子中,正确的答案是选择返回的类型是NUMERIC,这相当于一个十进制类型。使用long类型会导致强制转换异常。
这就是为什么要在不止一个谷歌搜索(甚至Stack Overflow!)中检查你的答案。
引用一位帮助过我的数据库管理员的话:
... BigInt和INT64是不一样的,不管它们看起来有多相似。部分原因是SQL经常将Int/BigInt转换为Numeric作为正常处理的一部分。所以当它转到OLE或。net时,所需的转换是NUMERIC到INT。 我们通常不会注意到,因为打印的值看起来是一样的。
sql中的int直接映射到int32,也被称为基本类型,即c#中的int
Sql Server中的bigint直接映射到int64,也被称为基本类型,即c#中的long
这里定义了biginteger到integer的显式转换
在c#中,大多数情况下它是long(int64)
您可以使用长类型或Int64
推荐文章
- 返回文件在ASP。Net Core Web API
- 自定义HttpClient请求头
- 如果我使用OWIN Startup.cs类并将所有配置移动到那里,我是否需要一个Global.asax.cs文件?
- VS2013外部构建错误"error MSB4019: The imported project <path> was not found"
- 从另一个列表id中排序一个列表
- 等待一个无效的异步方法
- 无法加载文件或程序集…参数不正确
- c#中枚举中的方法
- 如何将SQL Azure数据库复制到本地开发服务器?
- 如何从字符串中删除新的行字符?
- 如何设置一个默认值与Html.TextBoxFor?
- 检查属性是否有属性
- SQL Server 2008不能用新创建的用户登录
- 格式化XML字符串以打印友好的XML字符串
- 返回内容与IHttpActionResult非ok响应