はコードで自己いる場合、そのクラス内のC#の
class Class1
{
public string compute (string no1, string no2)
{
string computed;
if (Convert.ToInt32(no1) - 8 == 0)
{
if (Convert.ToInt32(no2) > 0)
{
computed = (60/Convert.ToInt32(no2)).ToString();
}
if (Convert.ToUInt32(no2) == 0)
{
computed = "0";
}
}
if (Convert.ToInt32(no1) - 8 != 1)
{
if (Convert.ToInt32(no2) > 0)
{
computed = ((Convert.ToInt32(no1) - 8) + (60/Convert.ToInt32(no2)).ToString();
}
if (Convert.ToInt32(no2) == 0)
{
computed = ((Convert.ToInt32(no1) - 8)).ToString();
}
}
return computed;
}
}
アイブ氏はまた、メインフォームで直接コードを使用しようとしましたが、私はそれを使用傾けますCommandTextで
connect.Open();
OleDbCommand command = new OleDbCommand();
command.Connection = connect;
command.CommandText = "update Table1 set ot='"+ computed +"' where Fname = '" + uname+"' ";
command.ExecuteNonQuery();
connect.Close();
MessageBox.Show("Save Complete");
も同じエラーが発生しました。
問題は、 '文字列computed'がそのif文の試合の非場合に割り当てられることはありませんということです。 –
この行の最後に 'computed'(Convert.ToInt32(no1) - 8)+(60/Convert.ToInt32(no2))。ToString(); 'がなくなっています – Hank
'var computed = string.Empty;'は空の値を返し、エラーはなくなります。 'computed'に何も割り当てられていなければエラーを返すべきですか? – Equalsk