代码:
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表中,调整数字字符串所在列的单元格格式的数字表示方式为文本,问题解决。