Regex.Replace メソッドを使用したいのですが、非常に長い文字列で "new long?((long)") 式を検索し、次の変更を行います。
前:
OracleParameter[] array = new OracleParameter[]
{
new OracleParameter("p_op_adi", OracleDbType.Varchar2, p_op_adi, ParameterDirection.Input),
new OracleParameter("p_tip_no", OracleDbType.Int64, p_tip_no, ParameterDirection.Input),
new OracleParameter("p_islem", OracleDbType.Varchar2, p_islem, ParameterDirection.Input),
new OracleParameter("p_raise", OracleDbType.Varchar2, p_raise, ParameterDirection.Input),
new OracleParameter("p_durum", OracleDbType.Int64, null, ParameterDirection.Output),
new OracleParameter("p_mesaj", OracleDbType.Varchar2, 4000, null, ParameterDirection.Output)
};
sMan.ExecuteSP("FRM_USER.user_yetki_kontrol_islem", array);
p_durum = ((array[4].Value != System.DBNull.Value) ? new long?((long)array[4].Value) : null);
p_mesaj = array[5].Value.ToString();
正規表現の後:
OracleParameter[] array = new OracleParameter[]
{
new OracleParameter("p_op_adi", OracleDbType.Varchar2, p_op_adi, ParameterDirection.Input),
new OracleParameter("p_tip_no", OracleDbType.Int64, p_tip_no, ParameterDirection.Input),
new OracleParameter("p_islem", OracleDbType.Varchar2, p_islem, ParameterDirection.Input),
new OracleParameter("p_raise", OracleDbType.Varchar2, p_raise, ParameterDirection.Input),
new OracleParameter("p_durum", OracleDbType.Int64, null, ParameterDirection.Output),
new OracleParameter("p_mesaj", OracleDbType.Varchar2, 4000, null, ParameterDirection.Output)
};
sMan.ExecuteSP("FRM_USER.user_yetki_kontrol_islem", array);
p_durum = abcde(array[4].Value);
p_mesaj = array[5].Value.ToString();
配列インデックス番号 4 をキャッチする必要があることに注意してください。