首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >简化OleDbDataReader代码

简化OleDbDataReader代码
EN

Stack Overflow用户
提问于 2013-02-26 16:37:47
回答 4查看 246关注 0票数 1

我做了一个程序,它读取数据库中的数据我使用OleDbDataReader,但问题是我有不同的表,这些代码工作得很好,但我发现它有点“硬编码”或recursive这是我的示例代码

代码语言:javascript
复制
        private void loadMilk()
        {
            cn.Open();
            OleDbDataReader reader = null;
            OleDbCommand cmd = new OleDbCommand("select* from Milk", cn);
            reader = cmd.ExecuteReader();
            while (reader.Read())
            {
                Milk.Add(reader["Product"].ToString());
            }
            cn.Close();
        }

我需要一次又一次地重复这一点,以便读取另一张表上的内容(例如,"select* from Fruit然后"select* from Classics...)有没有办法让我不会一次又一次地重复这段代码?谢谢。:)

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2013-02-26 16:41:57

您可以将该方法重构为如下所示:

代码语言:javascript
复制
private IList<string> Load(string tableName, string columnName)
{
    var result = new List<string>();
    cn.Open();
    OleDbDataReader reader = null;
    OleDbCommand cmd = new OleDbCommand(string.Format("select* from {0}", tableName), cn);
    reader = cmd.ExecuteReader();
    while (reader.Read())
    {
        result.Add(reader[columnName].ToString());
    }
    cn.Close();

    return result;
}

您的代码示例将是:

代码语言:javascript
复制
var milkItems = Load("Milk", "Product");
var classicItems = Load("Classics", "..."); //Enter the column here.

编辑

你可能想要一些更具体的东西(例如:存储List<SomeObject>而不仅仅是List<string>)。假设您有时想要返回一个Person列表,还想读取一个Building列表。然后,您可以编写类似这样的代码(未编译和测试的):

代码语言:javascript
复制
private IList<T> Load<T>(string tableName, Func<OleDbDataReader, T> selector)
{
    IList<T> result = new List<T>();
    cn.Open();
    OleDbDataReader reader = null;
    OleDbCommand cmd = new OleDbCommand(string.Format("select* from {0}", tableName), cn);
    reader = cmd.ExecuteReader();
    while (reader.Read())
    {
        result.Add(selector(reader));
    }
    cn.Close();

    return result;
}

你可以这样叫它:

代码语言:javascript
复制
Func<OleDbDataReader, Person> selector = x => new Person { Name = x["Person"].ToString() };
Load("People", selector);
票数 4
EN

Stack Overflow用户

发布于 2013-02-26 16:42:05

代码语言:javascript
复制
private void loadMilk(string TableName, string itemValue)
        {
            string SQLString = String.Format("select * from {0}",TableName);

            cn.Open();
            OleDbDataReader reader = null;
            OleDbCommand cmd = new OleDbCommand(SQLString, cn);
            reader = cmd.ExecuteReader();
            while (reader.Read())
            {
                Milk.Add(reader[ItemValue].ToString());
            }
            cn.Close();
        }
票数 3
EN

Stack Overflow用户

发布于 2013-02-26 16:43:48

不确定“牛奶”是什么类型。尝试:

代码语言:javascript
复制
private void loadObjectsFrom(string tableName, object obj, string column)
        {
            cn.Open();
            OleDbDataReader reader = null;
            OleDbCommand cmd = new OleDbCommand("select* from " + tableName, cn);
            reader = cmd.ExecuteReader();
            while (reader.Read())
            {
                obj.Add(reader[column].ToString());
            }
            cn.Close();
        }
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15084623

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档