0
OleDbConnection conn = new OleDbConnection(connectionString);
conn.Open();
OleDbCommand command = new OleDbCommand();
command.Connection = conn;
command.CommandText = "INSERT INTO myTbl ([username],[password],[firstname],[lastname],[mi],[age],[place],[contact])VALUES (?,?,?,?,?,?,?,?)";
command.Parameters.Add("@user", OleDbType.VarChar).Value = txtUsername.Text;
command.Parameters.Add("@psw", OleDbType.VarChar).Value = txtPassword.Text;
command.Parameters.Add("@nm", OleDbType.VarChar).Value = txtName.Text;
command.Parameters.Add("@Lname", OleDbType.VarChar).Value = txtLastName.Text;
command.Parameters.Add("@mIni", OleDbType.VarChar).Value = txtMI.Text;
command.Parameters.Add("@ag", OleDbType.Integer).Value = Convert.ToInt32(txtAge.Text);
command.Parameters.Add("@plc", OleDbType.VarChar).Value = txtPlace.Text;
command.Parameters.Add("@cntct", OleDbType.Integer).Value = Convert.ToInt32(txtContact.Text); ;
command.ExecuteNonQuery();
lblInfo.Visible = true;
lblInfo.Text = "Success";
conn.Close();

これにより、エラーが発生しますInput string was not in a correct format。私を助けてください。

4

2 に答える 2

1

コードとエラーに基づいて、TextBox コントロールのテキスト (txtContact または txtAge) の 1 つが有効な整数 (整数) 値ではない可能性があります。入力を検証していることを確認してください。RequiredFieldValidator と、RangeValidator または RegularExpressionValidator のいずれかを使用して、Textbox が空ではなく、有効なテキストが含まれていることを確認する必要があります。

Convert.ToInt32 の代わりにSystem.Int32.TryParse()の使用を検討することもできます。

于 2012-04-17T05:07:59.073 に答える
1

非整数値を整数値に変換しようとしています。 およびそれらの値を確認してくださいtxtAge.TexttxtContact.Text整数値に変換される値が含まれている必要があります。

于 2012-04-17T05:08:20.440 に答える