我有一个 IDbConnection 实例,它可以是任何连接、Sql、OleDb 等。我想做一个通用包装器,这样我就可以向包装器发送一个连接并获得一组很好的方法以便于操作。我有一个 Query 方法,我希望它返回一个 DataTable,所以我可以这样做
IDataAdapter adapter = new OleDbDataAdapter();
adapter.SelectCommand = myCommand;
DataSet ds = new DataSet();
adapter.Fill(ds);
问题是我必须使用 OleDbAdapter 并且它不适用于 SQL,我真的不想编写“驱动程序特定”代码。有没有办法从我实例化的 IDbConnection 对象中获取 IDataAdapter 实例?我知道我可以创建一个命令
IDbCommand command = _connection.CreateCommand();
认为必须有一些简单的方法来对 IDataAdapter 执行相同操作是合乎逻辑的。
编辑:
using (var reader = command.ExecuteReader())
{
var dataTable = new DataTable();
dataTable.Load(reader);
}
嗯,不完全是我要求的,而是一个很好的解决方案。