DataReader を使用したクエリ
CData ADO.NET Provider for Yahoo! JAPAN DATA SOLUTION では、次の2つのネイティブ.NET インターフェースを使用して、Yahoo! JAPAN DATA SOLUTION からデータを取得できます。YahooDSDataAdapter オブジェクトおよびYahooDSDataReader オブジェクト。各オブジェクトは同じタスク(データの取得)を実行しますが、実行方法が異なります。YahooDSDataAdapter オブジェクトはクエリに一致するすべてのデータを取得しますが、YahooDSDataReader オブジェクトは必要に応じてインクリメントしながら一部のデータだけをフェッチします。
YahooDSDataReader の使用
YahooDSDataReader はページ単位でデータを取得できるため、YahooDSDataAdapter よりもデータの取得が高速です。YahooDSDataReader からデータを読み取っていくと、必要に応じて一定の間隔で、データソースからの結果の次のページが要求されます。このため、結果が高速に返されます。 次の例は、SearchRanking テーブルからすべてのカラムを選択します。
C#
string connectionString = "AppID=12345678-1234-1234-1234-123456789012;"; using (YahooDSConnection connection = new YahooDSConnection(connectionString)) { YahooDSCommand cmd = new YahooDSCommand("SELECT * FROM SearchRanking", connection); YahooDSDataReader rdr = cmd.ExecuteReader(); while (rdr.Read()) { Console.WriteLine(String.Format("\t{0} --> \t\t{1}", rdr["SearchKeyword"], rdr["SearchPeriod"])); } }
VB.NET
Dim connectionString As String = "AppID=12345678-1234-1234-1234-123456789012;" Using connection As New YahooDSConnection(connectionString) Dim cmd As New YahooDSCommand("SELECT * FROM SearchRanking", connection) Dim rdr As YahooDSDataReader = cmd.ExecuteReader() While rdr.Read() Console.WriteLine([String].Format(vbTab & "{0} --> " & vbTab & vbTab & "{1}", rdr("SearchKeyword"), rdr("SearchPeriod"))) End While End Using