PDO を使用してデータベースに 'NULL' を動的に挿入しようとしています。
テーブル構造:
CREATE TABLE IF NOT EXISTS `Fixes` (
`Id` int(11) NOT NULL AUTO_INCREMENT COMMENT 'PK',
`CurrencyId` int(11) NOT NULL COMMENT 'FK',
`MetalId` int(11) NOT NULL COMMENT 'FK',
`FixAM` decimal(10,5) NOT NULL,
`FixPM` decimal(10,5) DEFAULT NULL,
`TimeStamp` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
PRIMARY KEY (`Id`),
KEY `CurrencyId` (`CurrencyId`),
KEY `MetalId` (`MetalId`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 COLLATE=latin1_general_ci AUTO_INCREMENT=13 ;
PHP/PDO クエリ:
$sql = 'UPDATE
Fixes
SET
FixAM = :fixAM,
FixPM = :fixPM
WHERE
MetalId IN (SELECT Id FROM Metals WHERE Name = :metal) AND
CurrencyId IN (SELECT Id FROM Currencies Where Id = :currency)';
$stmt = $db->prepare($sql);
for ($i = 0; $i<3; $i++) {
$stmt->execute(array(
':metal' => 'Silver',
':fixAM' => $fix['FixAM'][$i],
':fixPM' => $fix['FixPM'][$i],
':currency' => ($i+1))
);
}
たとえば、値$fix['FixPM'][$i]
が'NULL' の場合があります。これをデータベースに挿入するにはどうすればよいですか? クエリを実行してデータベースのデータを表示すると、このレコードは 0.0000 と表示され、null ではありません。
PDO を使用して NULL 値を挿入するにはどうすればよいですか? いくつかのソリューションを提供します。
$stmt->execute(array( ':v1' => null, ':v2' => ... ))
アイテムがnullの場合もあれば、そうでない場合もあるため、例のように使用できるとは思いません。そのため、作成した変数を参照し、必要に応じてその変数を$fix['FixPM'][$i]
nullにする必要があります
前もって感謝します。