【发布时间】:2013-01-06 16:29:29
【问题描述】:
我使用 Oledb 读取 AccessFile(.accdb) 到 DataSet,我不知道表名或列,常规实现是:
public void GetAccessDB(string filepath){
this.ConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source = " + filepath;
// get Table Names
this.TableNames = new List<string>();
using (System.Data.OleDb.OleDbConnection oledbConnection = new System.Data.OleDb.OleDbConnection(this.ConnectionString))
{
oledbConnection.Open();
System.Data.DataTable dt = null;
dt = oledbConnection.GetOleDbSchemaTable(System.Data.OleDb.OleDbSchemaGuid.Tables, null);
foreach (System.Data.DataRow row in dt.Rows)
{
string strSheetTableName = row["TABLE_NAME"].ToString();
if (row["TABLE_TYPE"].ToString() == "TABLE")
this.TableNames.Add(strSheetTableName);
}
oledbConnection.Close();
}
this.Dataset = new System.Data.DataSet();
using (System.Data.OleDb.OleDbConnection oledbConnection = new System.Data.OleDb.OleDbConnection(this.ConnectionString))
{
foreach (string table in this.TableNames)
{
string command = string.Format("SELECT * FROM {0};", table);
using (System.Data.OleDb.OleDbCommand cmd = new System.Data.OleDb.OleDbCommand(command, oledbConnection))
{
cmd.CommandType = System.Data.CommandType.Text;
oledbConnection.Open();
System.Data.OleDb.OleDbDataReader dr = cmd.ExecuteReader();
this.Dataset.Load(dr, System.Data.LoadOption.OverwriteChanges, table);
oledbConnection.Close();
}
}
}
}
但是我需要从 Stream 中获取访问文件,并且我不能将它临时写入磁盘,所以你有什么建议?
我需要GetAccessDB(Stream AccessFile) 的重载?
我搜索并找到This,但这对我来说并不清楚,我最终需要通过Access File中的所有表获取DataSet。
有人知道吗?
【问题讨论】:
-
为什么要在作为流打开的
Access文件中进行数据操作?只是好奇。 -
@AlexFilipovici 客户端上传访问文件,我需要读取它们并查找目标数据并存储在 SQL 上并向客户端显示目标数据表,但我不能(某些限制)写入文件到磁盘!
-
你为什么不能在本地磁盘上工作..?请更好地解释你的推理,以便其他人能够理解而不是像他们所说的那样把你引向黄金之路
-
数据库是否存储在 MS SQL Server 上?如果是,您可以控制哪个版本?
-
@AlexFilipovici SQL Server 2008,是的,我有任何控制权。
标签: c# c#-4.0 ms-access stream oledb