首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >CSV文件的OpenRowset返回空白或有错误。

CSV文件的OpenRowset返回空白或有错误。
EN

Stack Overflow用户
提问于 2016-11-23 08:41:40
回答 1查看 1.1K关注 0票数 0

因此,在前面,我即将创建一个代码,将计算机生成的CSV文件导入到我们的数据库中。我在Excel中创建了一个,我使用了以下代码

代码语言:javascript
复制
select *from openrowset('MSDASQL','Driver={Microsoft Access Text Driver (*.txt, *.csv)}'
,'select * from D:\Test.CSV')

而且效果很好。但当我处理实际数据时。以上代码不起作用。

因此,CSV文件包含一个前18行数据,其中信息可以被删除(它只是机器的名称),所需的数据位于第19行。

在搜索之后,我找到了一段代码,然后尝试使用CSV文件,它是

代码语言:javascript
复制
    SELECT *
        FROM OPENROWSET(BULK 'D:\Data\sample\device1_2016-08-03_15-24-58.csv',
        FORMATFILE='D:\Data\sample\BCPFormat.xml',
        FIRSTROW = 19) AS a

但数据是空白的!

我也试过这段代码

代码语言:javascript
复制
select * from OpenRowset('MSDASQL', 'Driver={Microsoft Access Text Driver (*.txt, *.csv)};DefaultDir=D:\Data\sample\;','select * from device1_2016-08-03_15-24-58.csv')

该错误声明:

代码语言:javascript
复制
An error occurred while preparing the query "select * from device1_2016-08-03_15-24-58.csv" for execution against OLE DB provider "MSDASQL" for linked server "(null)". 

我们使用的服务器DBMS是server 2008 R2。我们还使用MS Office 2010创建电子表格。

欢迎任何想法,谢谢您的提前!

编辑:

我将包括CSV文件的截图。

我还将包含XML文件(因为我已经读到FMT文件是XML文件,请检查这是否正确)。

代码语言:javascript
复制
<?xml version="1.0"?>
<BCPFORMAT xmlns="http://schemas.microsoft.com/sqlserver/2004/bulkload/format"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
 <RECORD>
  <FIELD ID="1" xsi:type="CharTerm" TERMINATOR=',' />
  <FIELD ID="2" xsi:type="CharTerm" TERMINATOR=',' />
  <FIELD ID="3" xsi:type="CharTerm" TERMINATOR=',' />
  <FIELD ID="4" xsi:type="CharTerm" TERMINATOR=','/>
  <FIELD ID="5" xsi:type="CharTerm" TERMINATOR=',' />
  <FIELD ID="6" xsi:type="CharTerm" TERMINATOR=',' />
  <FIELD ID="7" xsi:type="CharTerm" TERMINATOR=',' />
  <FIELD ID="8" xsi:type="CharTerm" TERMINATOR=',' />
  <FIELD ID="9" xsi:type="CharTerm" TERMINATOR=',' />
  <FIELD ID="10" xsi:type="CharTerm" TERMINATOR=',' />
  <FIELD ID="11" xsi:type="CharTerm" TERMINATOR=',' />
  <FIELD ID="12" xsi:type="CharTerm" TERMINATOR=',' />
  <FIELD ID="13" xsi:type="CharTerm" TERMINATOR=',' />
  <FIELD ID="14" xsi:type="CharTerm" TERMINATOR='\n' />
 </RECORD>
 <ROW>
  <COLUMN SOURCE="1" NAME="NO." xsi:type="SQLVARYCHAR" />
  <COLUMN SOURCE="2" NAME="Time" xsi:type="SQLVARYCHAR" />
  <COLUMN SOURCE="3" NAME="ms" xsi:type="SQLVARYCHAR" />
  <COLUMN SOURCE="4" NAME="degC1" xsi:type="SQLVARYCHAR" />
  <COLUMN SOURCE="5" NAME="degC2" xsi:type="SQLVARYCHAR" />
  <COLUMN SOURCE="6" NAME="degC3" xsi:type="SQLVARYCHAR" />
  <COLUMN SOURCE="7" NAME="degC4" xsi:type="SQLVARYCHAR" />
  <COLUMN SOURCE="8" NAME="degC5" xsi:type="SQLVARYCHAR" />
  <COLUMN SOURCE="9" NAME="degC6" xsi:type="SQLVARYCHAR" />
  <COLUMN SOURCE="10" NAME="A12345678901" xsi:type="SQLVARYCHAR" />
  <COLUMN SOURCE="11" NAME="A12345678902" xsi:type="SQLVARYCHAR" />
  <COLUMN SOURCE="12" NAME="A12345678903" xsi:type="SQLVARYCHAR" />
  <COLUMN SOURCE="13" NAME="A12345678904" xsi:type="SQLVARYCHAR" />
  <COLUMN SOURCE="14" NAME="A1234" xsi:type="SQLVARYCHAR" />
 </ROW>
</BCPFORMAT>

我已经在文本文件中包含了CSV文件的屏幕截图。

代码语言:javascript
复制
Vendor,GUARDIAN
Model,ZR-RX45
Version,Ver1.04
Sampling,10s
Total data points,0           
Start time,2016-08-03,15:25:01
End time,2016-08-03,15:24:59
Trigger time,2016-07-30,08:21:50
AMP Settings
CH,Signal name,Input,Range,Filter,Span
CH34, "PC-2",TEMP,TC_K,Off,250.000000,0.000000,degC
CH35, "PC-11",TEMP,TC_K,Off,250.000000,0.000000,degC
CH36, "PC-19",TEMP,TC_K,Off,250.000000,0.000000,degC
CH37, "PC-16",TEMP,TC_K,Off,250.000000,0.000000,degC
CH38, "PC-08",TEMP,TC_K,Off,250.000000,0.000000,degC
CH39, "PC-18",TEMP,TC_K,Off,250.000000,0.000000,degC
Logic/Pulse,Off
Data
Number,Date&Time,ms,CH34,CH35,CH36,CH37,CH38,CH39,Alarm1-10,Alarm11-20,Alarm21-30,Alarm31-40,AlarmOut
NO.,Time,ms,degC,degC,degC,degC,degC,degC,A1234567890,A1234567890,A1234567890,A1234567890,A1234
1,2016-07-30 08:21:50,000,+0.0,+0.0,+0.0,+0.0,+0.0,+0.0,LLLLLLLLLL,LLLLLLLLLL,LLLLLLLLLL,LLLLLLLLLL,LLLL
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-11-25 09:01:06

这是因为CSV中的每一行都没有正确的字段数,因此不能进行解析。即使您只要求第19行(或第21行)继续,整个文件仍然会被解析。

您可以通过将.CSV文件修改为每行都有14个字段(即13个逗号)来解决这个问题:

代码语言:javascript
复制
Vendor,GUARDIAN,,,,,,,,,,,,
Model,ZR-RX45,,,,,,,,,,,,
Version,Ver1.04,,,,,,,,,,,,
Sampling,10s,,,,,,,,,,,,
Total data points,0,,,,,,,,,,,,      
Start time,2016-08-03,15:25:01,,,,,,,,,,,
End time,2016-08-03,15:24:59,,,,,,,,,,,
Trigger time,2016-07-30,08:21:50,,,,,,,,,,,
AMP Settings,,,,,,,,,,,,,
CH,Signal name,Input,Range,Filter,Span,,,,,,,,,,,,
CH34, "PC-2",TEMP,TC_K,Off,250.000000,0.000000,degC,,,,,,,
CH35, "PC-11",TEMP,TC_K,Off,250.000000,0.000000,degC,,,,,,,
CH36, "PC-19",TEMP,TC_K,Off,250.000000,0.000000,degC,,,,,,,
CH37, "PC-16",TEMP,TC_K,Off,250.000000,0.000000,degC,,,,,,,
CH38, "PC-08",TEMP,TC_K,Off,250.000000,0.000000,degC,,,,,,,
CH39, "PC-18",TEMP,TC_K,Off,250.000000,0.000000,degC,,,,,,,
Logic/Pulse,Off,,,,,,,,,,,,
Data,,,,,,,,,,,,,
Number,Date&Time,ms,CH34,CH35,CH36,CH37,CH38,CH39,Alarm1-10,Alarm11-20,Alarm21-30,Alarm31-40,AlarmOut
NO.,Time,ms,degC,degC,degC,degC,degC,degC,A1234567890,A1234567890,A1234567890,A1234567890,A1234
1,2016-07-30 08:21:50,000,+0.0,+0.0,+0.0,+0.0,+0.0,+0.0,LLLLLLLLLL,LLLLLLLLLL,LLLLLLLLLL,LLLLLLLLLL,LLLL

那么你的命令起作用了:

代码语言:javascript
复制
SELECT a.*
FROM OPENROWSET(BULK 'D:\some_location\device1_2016-08-03_15-24-58.csv',
                FORMATFILE='D:\some_location\BCPFormat.xml',
                FIRSTROW = 21) AS a
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40759547

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档