[英]“Failed to convert parameter value from int64 to int32”
我正在向SQL Server表中插入一些值。 当我从前端获取值时,它们是字符串。 所以我需要先将它们转换为int
,然后才能将它们插入表中。
我正在使用此代码:
Int64 x = Convert.ToInt64(some string value);
我想将此x
插入表格中,类型为numeric(18,0)
的列中。
进行此转换时,出现错误
无法将参数值从int64转换为int32
而我的所有值都只有1000左右。
使用int x = Convert.ToInt32(some string value)
,它应该可以工作。
您的数据库需要一个Int32
类型的值。 由于潜在的信息丢失,SQL Server不会将64位数字隐式转换为32位数字。
一个Int64
范围从−9,223,372,036,854,775,808
到9,223,372,036,854,775,807
,正如你可以看到的是长19个字符(不包括引号),因此不会在18你数值范围适合如果你真的想使用Int64
为小号码,如1000,您应该将列修改为数据类型bigint
。
对于sql server端的System.Int64(长整数),必须使用bigint数据类型。 http://msdn.microsoft.com/en-us/library/ms187745.aspx
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.