using System; using System.Collections.Generic; using System.Data.OleDb; using System.Data; using System.Text; namespace SqlSugar { /// /// 数据填充器 /// public class OleDbDataAdapterNew : IDataAdapter { private OleDbCommand command; private string sql; private OleDbConnection _sqlConnection; /// /// SqlDataAdapter /// /// public OleDbDataAdapterNew(OleDbCommand command) { this.command = command; } public OleDbDataAdapterNew() { } /// /// SqlDataAdapter /// /// /// public OleDbDataAdapterNew(string sql, OleDbConnection _sqlConnection) { this.sql = sql; this._sqlConnection = _sqlConnection; } /// /// SelectCommand /// public OleDbCommand SelectCommand { get { if (this.command == null) { this.command = new OleDbCommand(this.sql, this._sqlConnection); } return this.command; } set { this.command = value; } } /// /// Fill /// /// public void Fill(DataTable dt) { if (dt == null) { dt = new DataTable(); } var columns = dt.Columns; var rows = dt.Rows; using (OleDbDataReader dr = command.ExecuteReader()) { for (int i = 0; i < dr.FieldCount; i++) { string name = dr.GetName(i).Trim(); if (!columns.Contains(name)) columns.Add(new DataColumn(name, dr.GetFieldType(i))); else { columns.Add(new DataColumn(name + i, dr.GetFieldType(i))); } } while (dr.Read()) { DataRow daRow = dt.NewRow(); for (int i = 0; i < columns.Count; i++) { daRow[columns[i].ColumnName] = dr.GetValue(i); } dt.Rows.Add(daRow); } } dt.AcceptChanges(); } /// /// Fill /// /// public void Fill(DataSet ds) { if (ds == null) { ds = new DataSet(); } using (OleDbDataReader dr = command.ExecuteReader()) { do { var dt = new DataTable(); var columns = dt.Columns; var rows = dt.Rows; for (int i = 0; i < dr.FieldCount; i++) { string name = dr.GetName(i).Trim(); if (!columns.Contains(name)) columns.Add(new DataColumn(name, dr.GetFieldType(i))); else { columns.Add(new DataColumn(name + i, dr.GetFieldType(i))); } } while (dr.Read()) { DataRow daRow = dt.NewRow(); for (int i = 0; i < columns.Count; i++) { daRow[columns[i].ColumnName] = dr.GetValue(i); } dt.Rows.Add(daRow); } dt.AcceptChanges(); ds.Tables.Add(dt); } while (dr.NextResult()); } } } }