我想使用 C# 对 CSV 文件使用 SQL 查询。这里的 java 有类似的东西。c#有这样的东西吗?
问问题
13792 次
5 回答
8
您可以使用 ODBC 对 CSV 文件运行查询:
// using System.Data.Odbc;
string strConn = @"Driver={Microsoft Text Driver (*.txt; *.csv)};" +
"Dbq=C:;Extensions=csv,txt";
OdbcConnection objCSV = new OdbcConnection(strConn);
objCSV.Open();
OdbcCommand oCmd = new OdbcCommand("select column1,column2 " +
"from THECSVFILE.CSV", objCSV);
OdbcDataReader oDR = oCmd.ExecuteReader();
while (oDR.Read())
{
// Do something
}
于 2012-05-16T18:23:28.593 回答
5
您可以使用适当的 OLE DB 提供程序来查询文本文件。您可以在此处找到查询字符串:
于 2012-05-16T18:18:17.847 回答
2
// need to add
// using System.Linq;
void Main()
{
var path = @"C:\myfile.csv";
string csv = System.IO.File.ReadAllText( path );
var array = csv.Split(new[]{","}, StringSplitOptions.RemoveEmptyEntries);
// Do the mapping with your databinding object
var personArray = array.Select(p => new Person { Name = p});
// You need to have this DataContext defined somewhere, for instance using LinqToSql
using(var context = new PersonDataContext()){
context.InsertAllOnSubmit(personArray);
context.SubmitChanges();
}
}
// Imagine this class is one of linqToSql class
public class Person{
public string Name {get;set;}
}
于 2012-05-16T18:26:43.317 回答
1
那么,您的意思是使用 Linq 吗?
像其中之一?
http://blogs.msdn.com/b/wriju/archive/2009/05/24/linq-to-csv-getting-data-the-way-you-want.aspx
http://blogs.msdn.com /b/ericwhite/archive/2008/09/30/linq-to-text-and-linq-to-csv.aspx
于 2012-05-16T18:18:33.097 回答
0
您可以使用 Openrowsets 。
首先在 SQL 配置中启用 SQL Ad Hoc/Openrowset。启用后,您将能够连接 SQL Server 管理工作室并查询 Excel 和逗号分隔的文件。
您的查询将类似于:
SELECT * FROM OPENROWSET('MSDASQL','Driver={Microsoft Text Driver (*.txt; *.csv)};DefaultDir={your path}','SELECT * FROM ypurtextfile.csv')
您可以在 C# 代码中使用这些查询,就像查询任何其他表一样。只需与您的经理核实他是否同意您在 SQL Server 上启用 ad hoc
于 2012-05-16T18:27:21.590 回答