所以我有一个想法,因为我发现很难为txtbox创建一个代码,它只允许使用c#在mysql中使用整数而不是字母。我的计划是为什么不将数据库列设置为整数而不是典型的varchar,如果你输入一个字母当然会转向和异常,所以在这种情况下我想捕获异常并提示一个消息框说“请输入只有整数” 。你觉得怎么样?
答案 0 :(得分:15)
最好使用正确的列数据类型来计划存储在其中的内容,但是检查字符串是否只包含数字非常容易 - 只需解析并查看是否返回错误:
int parsedValue;
if (!int.TryParse(textBox.Text, out parsedValue))
{
MessageBox.Show("This is a number only field");
return;
}
// Save parsedValue into the database
答案 1 :(得分:2)
Visual Studio已经内置了对此的支持(您也可以通过编码实现它)。这是你需要做的:
TextBox
附近拖动比较验证工具。ErrorMessage
并写入“警报:仅键入数字”。同样通过编码,你可以得到它:
protected void Button1_Click(object sender, EventArgs e)
{
int i;
if (!int.TryParse(textBox.Text, out i))
{
Label.Text = "This is a number only field";
return;
}
}
答案 2 :(得分:0)
你可以通过这种方式实现
int outParse;
// Check if the point entered is numeric or not
if (Int32.TryParse(propertyPriceTextBox.Text, out outParse) && outParse)
{
// Do what you want to do if numeric
}
else
{
// Do what you want to do if not numeric
}
答案 3 :(得分:0)
if(Int32.TryParse(textBox1.Text, out int value))
{
// Here comes the code if numeric
}
else
{
// Here comes the code if not numeric
}