我应该使用什么时候处理一个值在c#,这是一个SQL Server数据库的大int ?
这对应于long(或Int64),一个64位整数。
尽管如果来自数据库的数字恰好足够小,并且您不小心使用了Int32等等,那么就不会有问题。但Int64肯定会hold住它。
如果你使用更小的东西,而需要完整的尺寸,你得到的错误是什么?堆栈溢出!耶!
我刚刚有一个脚本,返回一个插入的主键,并使用
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的显式转换
我设法转换(bigint)值从DB返回使用convert . toint64。
ie
var Id = Convert.ToInt64(identityAsTable.Rows[0].Field<object>(0));
推荐文章
- 实体框架核心:在上一个操作完成之前,在此上下文中开始的第二个操作
- 如何为构造函数定制Visual Studio的私有字段生成快捷方式?
- 为什么Visual Studio 2015/2017/2019测试运行器没有发现我的xUnit v2测试
- 确定记录是否存在的最快方法
- 如何使用JSON确保字符串是有效的JSON。网
- AppSettings从.config文件中获取值
- 通过HttpClient向REST API发布一个空体
- 如何检查IEnumerable是否为空或空?
- 自动化invokerrequired代码模式
- 没有ListBox。SelectionMode="None",是否有其他方法禁用列表框中的选择?
- 在c#代码中设置WPF文本框的背景颜色
- 在c#中,什么是单子?
- 从现有模式生成表关系图(SQL Server)
- c#和Java中的泛型有什么不同?和模板在c++ ?
- 我如何循环通过一组记录在SQL Server?