av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

SQL Server導入excel數據之Bug!

瀏覽:129日期:2022-08-04 10:11:36
最近幫朋友把他整理的excel數據導入到Sql Server中,失敗,報錯如下:作為源列4(“產品說明”)的數據對于所指定的緩沖區來講太大。 我的excel文件中有一列叫“產品說明”,就是一些文字。Sql server處理導excel數據流程是這樣的,它會先創建目標表,再把excel數據寫入緩沖區,然后再把緩沖區數據寫入目標表。問題就在創建目標表和寫入緩沖區,sql server會根據現在的excel中的數據格式來寫入緩沖區和創建目標表。比如excel中有一列為編號,里面是數字,sqlserver就會在目標表里建一列叫“編號”,為float類型. 而對于我的excel文件中的'產品說明'這一列,是文字,那sql server如何建立目標列或緩沖區呢?它怎么知道該把目標建立成varchar還是text呢?經過測試,發現sql server是這樣做的,他會取excel文件中的前8行(2的三次方),然后算這8行里“產品說明”的最大長度,如果這8行里最長的 > 255,則目標列和緩沖區就會建立成ntext類型,否則就建立成nvarchar類型。這樣,問題就來了!假設我的excel文件前8行“產品說明”中都 < 255,則目標和緩沖區就被建立為varchar(255)類型了(這里說明一下,你可以修改目標表的字段類型,但緩沖區長度或類型是無法修改的)。而如果我的第10行里“產品說明”的長度超過了255,則sql server往緩沖區里寫的時候,自然就發生了如上的錯誤:數據對于指定的緩沖區來講太大。 這樣,我們導數據當然就失敗了!這個也許不能算bug,因為只是實現得不好(取某列前8行的最大長度并不能真正代表所有行,我想microsoft的工程師為了簡單或者提高性能才這樣做的);也許算是bug,因為不知情的用戶導數據失敗了。而且不知道為何而失敗的! 公理自在人心,讓大家或那些工程師們去評判吧!
標簽: excel
主站蜘蛛池模板: 国产区视频在线观看 | 国产精品国产成人国产三级 | 亚州一区二区三区 | 久久国产精品一区二区三区 | 亚洲精品成人网 | 亚洲视频在线播放 | 日韩中文字幕一区 | 精品久久久久国产 | 欧美国产在线一区 | 国产精品免费视频一区 | 国产精品欧美一区喷水 | 久久99精品久久久久 | 国产精品国产三级国产aⅴ入口 | 先锋资源网 | 久久久观看 | 可以免费观看的av | 黄色国产在线播放 | 二区精品| 亚洲精品一区国语对白 | 亚洲瑟瑟 | 国产999精品久久久 午夜天堂精品久久久久 | 日韩欧美三区 | 久久久在线视频 | 精品中文字幕一区二区三区 | 中文字幕91| 91成人免费看 | 电影91久久久 | 久久久国产精品入口麻豆 | 99热在这里只有精品 | 中文字幕人成乱码在线观看 | 国产高清在线精品一区二区三区 | 国产一区二区三区在线 | 亚洲国产一区二区三区 | 欧美一区二区在线观看 | 91久久久久久久久久久 | 成人网av | 国产黄色精品在线观看 | 一级片网址 | 中文字幕第100页 | 国产精品一区一区三区 | 成年人视频免费在线观看 |