次の2つの例はどれが正しいですか?私はこれを見つけた"using"ステートメントの内部でSqlDataReaderを使用する必要がありますか?
MSDNで(あるいは、どちらが優れていると私は使用する必要があります):
private static void ReadOrderData(string connectionString)
{
string queryString = "SELECT OrderID, CustomerID FROM dbo.Orders;"
using (SqlConnection connection = new SqlConnection(connectionString))
{
SqlCommand command = new SqlCommand(queryString, connection);
connection.Open();
SqlDataReader reader = command.ExecuteReader();
// Call Read before accessing data.
while (reader.Read())
{
Console.WriteLine(String.Format("{0}, {1}", reader[0], reader[1]));
}
// Call Close when done reading.
reader.Close();
}
}
ただし、一部のユーザーはそれをこのように行うことをお勧め他のページ探して:だから
private static void ReadOrderData(string connectionString)
{
string queryString = "SELECT OrderID, CustomerID FROM dbo.Orders;";
using (SqlConnection connection = new SqlConnection(connectionString))
{
using (SqlCommand command = new SqlCommand(queryString, connection))
{
connection.Open();
using (SqlDataReader reader = command.ExecuteReader())
{
// Call Read before accessing data.
while (reader.Read())
{
Console.WriteLine(String.Format("{0}, {1}", reader[0], reader[1]));
}
}
}
}
}
を問題は:SqlCommand
とSqlDataReader
にもusing
ステートメントを使用するか、SqlConnection
using
コードブロックの末尾に自動的に配置するかどうかです。
[SqlDataReaderを手動で閉じて処分する必要がありますか?](http://stackoverflow.com/questions/744051/is-it-necessary-to-manually-close-and-dispose-of- –
関連項目:[DataReaderを閉じるために "using"ステートメントを置くことはできますか?](http://stackoverflow.com/q/2157276/456814)。 –