我创建了一个表单,其中包含用于接受浮动值作为输入的字段。我的目标是能够将这些值存储在数据库中并在以后使用它们。到目前为止我尝试过的所有事情都导致了失败。
我尝试将输入字段类型从文本更改为数字,浮点数和偶数,步长较小。似乎当我用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());
答案 0 :(得分:1)
使用DECIMAL数据类型而不是Float。如this link中所述,有时浮点值会导致问题,而Decimal工作正常。
像这样使用它:
CREATE TABLE t1 (i INT, d1 DECIMAL(9,2), d2 DECIMAL(9,2));
这里9是精度,2是刻度。相应地改变