因为项目中一直使用Enterprise Library- Data Block oralce作服务器端的应用。现在要做一个桌面的应用。为了统一,也准备使用 Enterprise Library- Data Block 来做 MS Access 。于是就上网找了 Enterprise Library的Oledb的源代码,回来自己手动编译生成 dll 。

/Files/culturenet/OleDbData.zip

配置以后,使用代码如下:
 
Enterprise Library- Data Block 使用MS Access的问题的解决Database db = DatabaseFactory.CreateDatabase("AccessDb");
Enterprise Library- Data Block 使用MS Access的问题的解决    
string sqlCommand = "SELECT * FROM MYRESOURCE";
Enterprise Library- Data Block 使用MS Access的问题的解决    DBCommandWrapper dbCommandWrapper 
=db.GetStoredProcCommandWrapper(sqlCommand);
Enterprise Library- Data Block 使用MS Access的问题的解决       DataSet ds
=db.ExecuteDataSet(dbCommandWrapper);
Enterprise Library- Data Block 使用MS Access的问题的解决    dataGrid1.DataSource
=ds.Tables[0];
Enterprise Library- Data Block 使用MS Access的问题的解决

使用中发生异常。
跟踪发现,原来是 传入 的 Command 的 CommandType 为 StoredProcedure 造成的。

于是乎就有两种做法来避免异常:

1、在Access中用 SELECT * FROM MYRESOURCE  建立一个查询,名字为:SOURCE

使用代码为:
Enterprise Library- Data Block 使用MS Access的问题的解决    Database db = DatabaseFactory.CreateDatabase("AccessDb");
Enterprise Library- Data Block 使用MS Access的问题的解决                
string sqlCommand = "SOURCE";
Enterprise Library- Data Block 使用MS Access的问题的解决                DBCommandWrapper dbCommandWrapper 
=db.GetStoredProcCommandWrapper(sqlCommand);
Enterprise Library- Data Block 使用MS Access的问题的解决                DataSet ds
=db.ExecuteDataSet(dbCommandWrapper);
Enterprise Library- Data Block 使用MS Access的问题的解决                dataGrid1.DataSource
=ds.Tables[0];

2、直接在代码中指定 CommandType 为 text

代码如下:
Enterprise Library- Data Block 使用MS Access的问题的解决    Database db = DatabaseFactory.CreateDatabase("AccessDb");
Enterprise Library- Data Block 使用MS Access的问题的解决                
string sqlCommand = "SELECT * FROM MYRESOURCE";
Enterprise Library- Data Block 使用MS Access的问题的解决                DBCommandWrapper dbCommandWrapper 
=db.GetStoredProcCommandWrapper(sqlCommand);
Enterprise Library- Data Block 使用MS Access的问题的解决                dbCommandWrapper.Command.CommandType
=CommandType.Text;
Enterprise Library- Data Block 使用MS Access的问题的解决                DataSet ds
=db.ExecuteDataSet(dbCommandWrapper);
Enterprise Library- Data Block 使用MS Access的问题的解决                dataGrid1.DataSource
=ds.Tables[0];

呵呵,今天早上忽然记起来,可以使用 GetSqlStringCommandWrapper 方法来代替 GetStoredProcCommandWrapper,就不用设置CommandType了。昨天晚上肯定是晕了,以前经常用的方法都给忘了。

相关文章:

  • 2021-04-18
  • 2021-07-15
  • 2021-11-15
  • 2021-09-21
猜你喜欢
  • 2021-07-11
  • 2021-10-05
  • 2021-05-21
  • 2021-09-22
相关资源
相似解决方案