あるテーブルから別のテーブルに複数の行をコピーしようとしていますが、選択した最後のエントリのみが保存されます。データの配列を印刷すると、すべてが表示されます。私がコピーしているテーブルには auto_increment が設定されておらず、それが理由についての私の推測だったので、今は困惑しています。
foreach($this->request->data['Order']['archive_value'] as $orderid){
$data = $this->Order->query("select * from orders where orderid = '$orderid'");
$newdata = array(
'ArchivedOrder' => array(
'orderid' => $data[0]['orders']['orderid'],
'id' => $data[0]['orders']['id'],
'order_status' => $data[0]['orders']['order_status'],
'email' => $data[0]['orders']['email'],
'total' => $data[0]['orders']['total'],
'fullName' => $data[0]['orders']['fullName'],
'address' => $data[0]['orders']['address'],
'city' => $data[0]['orders']['city'],
'state' => $data[0]['orders']['state'],
'zip' => $data[0]['orders']['zip'],
'created' => $data[0]['orders']['created'],
'modified' => $data[0]['orders']['modified']
));
print_r($newdata); //this shows every entry that I look up, but it's not saving them properly
$this->loadModel('ArchivedOrder');
$this->ArchivedOrder->save($newdata);
///$this->Order->query("delete from orders where orderid = '$orderid'");
}
PHPMyAdmin からテーブル構造をダンプすると、これが表示されます
CREATE TABLE `archived_orders` (
`orderid` int(10) default NULL,
`id` int(10) default NULL,
`order_status` varchar(20) default NULL,
`email` varchar(50) default NULL,
`total` varchar(50) default NULL,
`fullName` varchar(60) default NULL,
`address` varchar(50) default NULL,
`city` varchar(50) default NULL,
`state` varchar(50) default NULL,
`zip` varchar(15) default NULL,
`created` datetime default NULL,
`modified` datetime default NULL
) ENGINE=MyISAM DEFAULT CHARSET=utf8;