0

入力として浮動値を受け入れるために使用されるフィールドを含むフォームを作成しました。私の目標は、これらの値を DB に保存し、後で使用できるようにすることです。私がこれまでに試したことはすべて失敗に終わりました。

入力フィールドのタイプをテキストから数値、浮動小数点数、偶数に小さなステップ サイズで変更してみました。フィールドの値をphpでリクエストしてDBに送信すると、何かがうまくいかず、最も近い整数のみが格納されるようです。アイデア?

私のフォームコードは次のとおりです。

<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());
4

1 に答える 1

1

Float の代わりに DECIMAL データ型を使用します。このリンクで説明されているように、浮動小数点値が問題を引き起こすことがありますが、Decimal は正常に機能します。

次のように使用します。

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

ここで 9 は精度で、2 はスケールです。それに応じて変更します

于 2012-06-20T19:38:39.767 に答える