gpt4 book ai didi

PHP:验证十进制 Mysqli 数据类型

转载 作者:行者123 更新时间:2023-11-29 08:05:52 25 4
gpt4 key购买 nike

我有一个具有如下列数据类型的表:

price decimal(6,2) unsigned NOT NULL,

我的验证代码是这样的:

if ( (!empty($_POST['price'])) && (is_numeric($_POST['price'])) && (isset($_POST['price'])) > 0 ) {
$price = ($_POST['price']);

} else{
$price = FALSE;
echo '<p> Only accept number and must be higher than zero</p>';

}

我使用 $_POST 表单让用户提交值。但你知道,

1/当用户键入任何非数字值(例如 a、b、c 等)时,它也可以很好地验证。2/当用户输入值零时,它也能很好地验证。

但是,问题是,当我在没有输入任何值的情况下对其进行测试时。我的意思是,我将值留空并点击“提交”按钮,错误消息仍然按照 }else { 部分确实如此,但技术上该值仍然以 0.00 的值同时插入到表列中。

据我有限的知识,我猜测问题可能出在我选择的表的 Mysqli 数据类型上,但我不知道如何纠正它。

你能帮我一下吗?

最佳答案

我认为您正在寻找的解决方案是将插入代码简单地移至第一个 if 语句。这样,它只会插入数字且不为空的值。

关于PHP:验证十进制 Mysqli 数据类型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22753028/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com