回答:
using(SqlDataReader rdr = cmd.ExecuteReader())
{
while (rdr.Read())
{
var myString = rdr.GetString(0); //The 0 stands for "the 0'th column", so the first column of the result.
// Do somthing with this rows string, for example to put them in to a list
listDeclaredElsewhere.Add(myString);
}
}
string col1Value = rdr["ColumnOneName"].ToString();
または
string col1Value = rdr[0].ToString();
これらはobject
sなので、キャストするかにする必要があります.ToString()
。
while(rdr.Read())
{
string col=rdr["colName"].ToString();
}
それは働きます
toString()
無効なのは.ToString()
単にfyiでなければなりません
それを使用できる人のために私のヘルパーメソッドを共有すると思いました:
public static class Sql
{
public static T Read<T>(DbDataReader DataReader, string FieldName)
{
int FieldIndex;
try { FieldIndex = DataReader.GetOrdinal(FieldName); }
catch { return default(T); }
if (DataReader.IsDBNull(FieldIndex))
{
return default(T);
}
else
{
object readData = DataReader.GetValue(FieldIndex);
if (readData is T)
{
return (T)readData;
}
else
{
try
{
return (T)Convert.ChangeType(readData, typeof(T));
}
catch (InvalidCastException)
{
return default(T);
}
}
}
}
}
使用法:
cmd.CommandText = @"SELECT DISTINCT [SoftwareCode00], [MachineID]
FROM [CM_S01].[dbo].[INSTALLED_SOFTWARE_DATA]";
using (SqlDataReader data = cmd.ExecuteReader())
{
while (data.Read())
{
usedBy.Add(
Sql.Read<String>(data, "SoftwareCode00"),
Sql.Read<Int32>(data, "MachineID"));
}
}
ヘルパーメソッドは任意の値にキャストします。キャストできない場合、またはデータベースの値がNULLの場合、結果はnullになります。
reader.GetColumn<int>("M_ID");
私はこれが少し古いことを知っていますが、SqlDataReaderのコンテンツをクラスに読み込んでいる場合、これは非常に便利です。リーダーとクラスの列名は同じである必要があります
public static List<T> Fill<T>(this SqlDataReader reader) where T : new()
{
List<T> res = new List<T>();
while (reader.Read())
{
T t = new T();
for (int inc = 0; inc < reader.FieldCount; inc++)
{
Type type = t.GetType();
string name = reader.GetName(inc);
PropertyInfo prop = type.GetProperty(name);
if (prop != null)
{
if (name == prop.Name)
{
var value = reader.GetValue(inc);
if (value != DBNull.Value)
{
prop.SetValue(t, Convert.ChangeType(value, prop.PropertyType), null);
}
//prop.SetValue(t, value, null);
}
}
}
res.Add(t);
}
reader.Close();
return res;
}
ここでの使用は反対SqlDataReader
です。ADO.NETには多くのエッジケースと複雑な問題があり、私の経験では、ほとんどの手動で作成されたADO.NETコードは少なくとも 1つの方法(通常は微妙で状況依存)で壊れています。
これを回避するためのツールが存在します。たとえば、ここで文字列の列を読み取りたい場合です。Dapperはそれを完全に無痛にします:
var region = ... // some filter
var vals = connection.Query<string>(
"select Name from Table where Region=@region", // query
new { region } // parameters
).AsList();
ここのDapperは、すべてのパラメーター化、実行、および行処理、およびADO.NETの他の多くの汚れた詳細を扱っています。<string>
交換することができる<SomeType>
オブジェクトに行全体をマテリアライズします。
簡単に言うと、クエリがcolumn_nameを返し、文字列を保持している場合は、次のようになります。
while (rdr.Read())
{
string yourString = rdr.getString("column_name")
}
私は次のようなヘルパー関数を持っています:
public static string GetString(object o)
{
if (o == DBNull.Value)
return "";
return o.ToString();
}
次に、それを使用して文字列を抽出します。
tbUserName.Text = GetString(reader["UserName"]);
私は通常、この方法でデータリーダーによってデータを読み取ります。小さな例を追加しました。
string connectionString = "Data Source=DESKTOP-2EV7CF4;Initial Catalog=TestDB;User ID=sa;Password=tintin11#";
string queryString = "Select * from EMP";
using (SqlConnection connection = new SqlConnection(connectionString))
using (SqlCommand command = new SqlCommand(queryString, connection))
{
connection.Open();
using (SqlDataReader reader = command.ExecuteReader())
{
if (reader.HasRows)
{
while (reader.Read())
{
Console.WriteLine(String.Format("{0}, {1}", reader[0], reader[1]));
}
}
reader.Close();
}
}
あなたはread
database column
ここにいる必要があります。あなたは次のコードスニペットを見ることができます
string connectionString = ConfigurationManager.ConnectionStrings["NameOfYourSqlConnectionString"].ConnectionString;
using (var _connection = new SqlConnection(connectionString))
{
_connection.Open();
using (SqlCommand command = new SqlCommand("SELECT SomeColumnName FROM TableName", _connection))
{
SqlDataReader sqlDataReader = command.ExecuteReader();
if (sqlDataReader.HasRows)
{
while (sqlDataReader.Read())
{
string YourFirstDataBaseTableColumn = sqlDataReader["SomeColumn"].ToString(); // Remember Type Casting is required here it has to be according to database column data type
string YourSecondDataBaseTableColumn = sqlDataReader["SomeColumn"].ToString();
string YourThridDataBaseTableColumn = sqlDataReader["SomeColumn"].ToString();
}
}
sqlDataReader.Close();
}
_connection.Close();