将excel数据导入sql中,出现科学计数法

excel是先填入了数据,又设置成文本格式的,插入到sql的表中有的就显示成科学计数法的格式,有没有办法不修改excel的格式,修改代码,让表显示正确?... excel是先填入了数据,又设置成文本格式的,插入到sql的表中有的就显示成科学计数法的格式,有没有办法不修改excel的格式,修改代码,让表显示正确? 展开
 我来答
法力斯
2013-03-14 · 超过13用户采纳过TA的回答
知道答主
回答量:54
采纳率:0%
帮助的人:42.1万
展开全部
这个问题我遇到过。
办法就是数据库建表的时候把对应列定义成字符型,如果需要计算或判断的时候记得转换格式,比如 oracle 中用 to_number,其他的可能是 cast。
更多追问追答
追问
我设置断点看了一下,程序中从excel中读取的时候就已经是科学计数法的格式了,比如在excel中数据时33010061,在代码中插入到表中时就已经是科学计数法了,是不是非得要先设置成文本格式,再填入数据才行?我现在这个是填入了数据了,又设置成文本格式的。
追答
对,sql建表的时候就先设置成字符型。
吴昊的博客
2013-03-14 · 超过10用户采纳过TA的回答
知道答主
回答量:58
采纳率:0%
帮助的人:35.7万
展开全部
用fill方法,直接将exel映射成table
更多追问追答
追问
不是太懂,麻烦能详细说一下吗
追答
昨天下班了,现在给你源代码看。再不行发邮件到我邮箱Router_Wu@hotmail.com给你解答!
DataTable dt = new DataTable();

try
{
string strConn = "Provider=Microsoft.Ace.OleDb.12.0;" + "data source=" + Path + ";Extended Properties='Excel 12.0; HDR=Yes; IMEX=1'"; //此连接可以操作.xls与.xlsx文件 (支持Excel2003 和 Excel2007 的连接字符串)

OleDbConnection conn = new OleDbConnection(strConn);
conn.Open();

string strExcel = "";
OleDbDataAdapter myCommand = null;
strExcel = "select * from ["+ TableName + "$]";//此处TableName是Excel的sheet名

myCommand = new OleDbDataAdapter(strExcel, strConn);
dt = new DataTable();
myCommand.Fill(dt);
conn.Close();
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
nuii360
2013-03-14 · TA获得超过270个赞
知道答主
回答量:210
采纳率:0%
帮助的人:82.9万
展开全部
你数据库的表是什么字段类型,如果是字符型,那么可以调整插入代码。如果不是,那么就是你的数据表结果显示工具的事情了。
追问
是varchar类型的。
追答
如果这列肯定是数字的话,可以加个判断,如果是科学计数法,转换成数字。有现成的转换方法的。
来自:求助得到的回答
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
yfy415
2013-03-14
知道答主
回答量:40
采纳率:0%
帮助的人:18万
展开全部
可以将字段设置保留几位数
追问
字段?什么意思,麻烦详细说一下,谢谢
追答
是否可以将其设置为float类型
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
局泰烟南风
2019-02-17 · TA获得超过1241个赞
知道小有建树答主
回答量:1912
采纳率:100%
帮助的人:9.4万
展开全部
excel设置文本格式
你对整列设置就可以了,怎么会
“一个个双击”

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式