さて、codeigniterシステム内のCI_DB_pdo_driverの_execute()関数が正しく機能していないことがわかりました。おそらく、phpバージョンが原因です。とにかく、CodeIgniterのコードを次のように変更しました:
function _execute($sql)
{
$sql = $this->_prep_query($sql);
$result_id = $this->conn_id->prepare($sql);
$result_id->execute();
if (is_object($result_id))
{
if (is_numeric(stripos($sql, 'SELECT')))
{
$this->affect_rows = count($result_id->fetchAll());
$result_id->execute();
}
else
{
$this->affect_rows = $result_id->rowCount();
}
}
else
{
$this->affect_rows = 0;
}
return $result_id;
}
TO:
function _execute($sql)
{
$sql = $this->_prep_query($sql);
$result_id = $this->conn_id->prepare($sql);
$result_id->execute();
if (is_object($result_id))
{
if (preg_match('/^\s*"?(SELECT)\s+/i', $sql))
{
$this->affect_rows = count($result_id->fetchAll());
$result_id->execute();
}
else
{
$this->affect_rows = $result_id->rowCount();
}
}
else
{
$this->affect_rows = 0;
}
return $result_id;
}
$ sqlに「SELECT」が含まれているかどうかをテストする部分が機能していなかったため、INSERTを実行しようとすると、「$ result_id-> execute()」が2回呼び出されていました。