如何接受html表单中的浮点值并将其发送到MySQL DB

时间:2012-06-20 19:26:36

标签: php javascript mysql html

我创建了一个表单,其中包含用于接受浮动值作为输入的字段。我的目标是能够将这些值存储在数据库中并在以后使用它们。到目前为止我尝试过的所有事情都导致了失败。

我尝试将输入字段类型从文本更改为数字,浮点数和偶数,步长较小。似乎当我用php请求字段的值然后将其发送到我的数据库时,出现问题并仅存储最接近的整数。想法?

我的表单代码是:

<form name ="chemAdd"  action="submitChemData.php" method="POST" id="chemData">

                <fieldset>
                <legend>Chemical Information</legend>
                <label for="chemName">Chemical Name:</label>
                <input type="text" name="chemName" />

                <label for="chemFormula">Molecular Formula:</label>
                <input type="text" name="chemFormula" />
                </fieldset>
                <br />

                <fieldset>
                <legend>Antoine Constants</legend>
                <label for="A">A:</label>
                <input type="number" name="A" size="10" min="0" max="9999" step="0.00000001" />

                <label for="B">B:</label>
                <input type="float" name="B" size="10"/>

                <label for="C">C:</label>
                <input type="text" name="C" size="10"/>

                <br /><br />

                <label for="unitT">Unit (Temperature):</label>
                    <select name="unitT" >
                        <option value="K">Kelvin</option>
                        <option value="C">Celcius</option>
                        <option value="F">Fahrenheit</option>
                    </select>

                <label for="unitP">Unit (Pressure):</label>
                    <select name="unitP" >
                        <option value="P">Pascal</option>
                        <option value="Hg">mm Hg</option>
                        <option value="bar">bar</option>
                    </select>

                </fieldset>
                <br />
                <fieldset>
                <legend>Reference Information</legend>
                <label for="Tmin">Temp. Minimum:</label>
                <input type="float" name="Tmin" size="10"/>

                <label for="Tmax">Temp. Maximum:</label>
                <input type="float" name="Tmax" size="10"/>
                <br /><br />
                <label for="Reference">Reference:</label>
                <input type="text" name="Reference" size="60"/>

                </fieldset>
                <br />
                <input type="submit"  value="Add to Database" id="submit" />    

                </form>
            </form>

我的PHP代码是:

  require_once 'dbConnectChem.php';


$name = trim(strtoupper($_REQUEST['chemName']));  
$formula= trim(strtoupper($_REQUEST['chemFormula']));  
$A =  $_REQUEST['A']; 
$B = $_REQUEST['B']; 
$C = $_REQUEST['C']; 
$unitT = $_REQUEST['unitT']; 
$unitP = $_REQUEST['unitP']; 
$Tmin = $_REQUEST['Tmin']; 
$Tmax = $_REQUEST['Tmax']; 
$Reference = $_REQUEST['Reference']; 


//INSERT Query
mysql_query("INSERT INTO Antoine (Name,Formula,A,B,C,unit_T,unit_P,Tmin,Tmax,Reference) VALUES ('{$name}','{$formula}','{$A}','{$B}','{$C}','{$unitT}','{$unitP}','{$Tmin}','{$Tmax}','{$Reference}') ")
    or die(mysql_error());

1 个答案:

答案 0 :(得分:1)

使用DECIMAL数据类型而不是Float。如this link中所述,有时浮点值会导致问题,而Decimal工作正常。

像这样使用它:

CREATE TABLE t1 (i INT, d1 DECIMAL(9,2), d2 DECIMAL(9,2));

这里9是精度,2是刻度。相应地改变