Arithmetic overflow error converting expression to data type nvarchar

代码:

insert into students
select * from 
openrowset('Microsoft.ACE.OLEDB.12.0','Excel 12.0;hdr=yes;database=D:\Document\Visual Studio 2017\C#面向对象程序设计\C#程序设计与实践\学生信息管理系统\Student\Excel\学生信息.xlsx',[学生信息$]);

数据:

错误信息:

Msg 8115, Level 16, State 2, Line 39
Arithmetic overflow error converting expression to data type nvarchar.
The statement has been terminated.

意思是:将表达式转换成数据类型nvarchar时出现算术溢出错误

原因分析:

1.首先考虑表头结构设置问题,即执行查询时,A1~F1这六个单元格虽然看上去合并了,但事实上是依然在那里的,这六个单元格里面都存储了相同的数据“学生信息”,且它们都是同步变化的;基于这一规则,SQL依然把第一行当作字段名所在行而将其忽略;问题未解决。正常情况下,图中的第二行会被当作数据导入到SQL中,此问题参考https://mp.csdn.net/postedit/91536523

2.excel默认将数字串存储为数字格式,SQL读取其数据时,把数字格式的excel数据读取为int型,但数字串表示的数据大小超出int型数据的最大范围时,就会发生数据溢出错误

此例中的"联系电话"字段的数据时数字型,int型数据的范围为-2,147,483,648   至   2,147,483,647,最高只有10位,而这里的电话号码是11位的,因此发生溢出错误。

解决:在excel表中,调整数字字符串所在列的单元格格式的数字表示方式为文本,问题解决。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值