以下のパラメーターのバインドに問題があります。パラメータを使用せずにテストしたため、接続は機能します。ただし、実行前のクエリの値は、たとえば「jsmith」ではなく「@userName」を使用しています。
何が問題ですか?これはバインディングを回避する正しい方法ではありませんか?
public static String GetFullName(String domainUser)
{
DataTable dT;
String fullName = "";
OracleConnection db = DatabaseAdapter.GetConn();
db.Open();
OracleCommand oraCommand = new OracleCommand("SELECT fullname FROM user_profile WHERE domain_user_name = '@userName'", db);
oraCommand.BindByName = true;
oraCommand.Parameters.Add(new OracleParameter("@userName", domainUser));
OracleDataReader oraReader = null;
oraReader = oraCommand.ExecuteReader();
if (oraReader.HasRows)
{
while (oraReader.Read())
{
fullName = oraReader.GetString(0);
}
}
else
{
return "No Rows Found";
}
oraReader.Close();
db.Close();
db.Dispose();
return fullName;
}
編集:パラメータフィールド名に@を追加しましたが、それでも修正されません。