0

SQL Server 2008 データベースに接続し、SQLSELECTステートメントを実行する Winforms アプリを考えてみます。

string myConnectionString = "Provider=SQLOLEDB;Data Source=hermes;Initial Catalog=qcvaluestest;Integrated Security=SSPI;";

string mySelectQuery = "SELECT top 500 name, finalconc from qvalues where rowid between 0 and 25000;";

OleDbConnection myConnection = new OleDbConnection(myConnectionString);

OleDbCommand myCommand = new OleDbCommand(mySelectQuery, myConnection);

myCommand.Connection.Open();

OleDbDataReader myReader = myCommand.ExecuteReader(CommandBehavior.CloseConnection);

クエリの結果をリストに読み込むにはどうすればよいでしょうか?

4

3 に答える 3

3

次のようなクラスを定義したと仮定します

class MyData
{
    public string Name {get; set;}
    public int FinalConc {get; set;} // or whatever the type should be
}

クエリの結果を繰り返し処理して、リストをロードします。

List<MyData> list = new List<MyData>();
while (myReader.Read())
{
    MyData data = new MyData();
    data.Name = (string)myReader["name"];
    data.FinalConc = (int)myReader["finalconc"]; // or whatever the type should be
    list.Add(data);
}

// work with the list

指定されたフィールドの1つだけが必要な場合は、クラス定義を省略して、List<T>保持Tするフィールドのタイプを指定するだけで済みます。

于 2010-11-03T17:16:58.473 に答える
2

あなたは次のように何かを試すことができます(あなたの便宜のためにそれを適応させてください):

public class Person
{
    public string Name { get; set; }
    public int Age { get; set; }
}

List<Person> dbItems = new List<Person>();

while(myReader.Read())
{
   Person objPerson = new Person();

   objPerson.Name = Convert.ToString(myReader["Name"]);
   objPerson.Age = Convert.ToInt32(myReader["Age"]);

   dbItems.Add(objPerson);
}
于 2010-11-03T17:17:03.913 に答える
1

何のリスト?と のプロパティを持つクラス設定はnameありfinalconcますか? すると、次のようになります。

public class QueryResult
{
    public string Name { get; set; }
    //not sure what finalconc type would be, so here just using string
    public string FinalConc { get; set; }
}

次に、次のようにします。

var queryResults = new List<QueryResult>();
using(var myReader = myCommand.ExecuteReader())
{
    while(myReader.Read())
    {
        queryResults.Add(new QueryResult
            { 
                Name = myReader.GetString(myReader.GetOrdinal("name")), 
                FinalConc = myReader.GetString(myReader.GetOrdinal("finalconc"))
            });
    }
}
于 2010-11-03T17:19:56.413 に答える