2014-09-01 7 views
5

Używam PDO w moim php ramach (lot) i mam niedorzeczny problem. Po wstawieniu 1 wiersza do mysql widziałem 3 wiersze wstawione.PDO: wstaw 3 wiersze zamiast w mysql kiedy wstawiam tylko 1 wiersz

Flight::db()->query("INSERT INTO `menu_item`(`order`, `menu_cat_id`) VALUES (22,1)"); 

To jest mój cały kod:

<?php 
require 'flight/Flight.php'; 

Flight::register('db', 'PDO', array('mysql:host=localhost;port=3306;dbname=deliman', 'root', ''), function($db) { 
     $db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); 
     $db->setAttribute(PDO::MYSQL_ATTR_INIT_COMMAND, "SET NAMES 'utf8'"); 
     $db->exec("SET NAMES 'utf8';"); 
     $db->setAttribute(PDO::ATTR_EMULATE_PREPARES, 0); 
}); 

Flight::route('/menu/item/new', function(){ 
     //$conn = Flight::db(); 
     $data = Flight::db()->query("INSERT INTO `menu_item`(`order`, `menu_cat_id`) VALUES (22,1)"); 

     //SET @maxOrder := (SELECT `order` FROM `menu_item` WHERE `menu_cat_id` = 1 ORDER BY `order` DESC LIMIT 1) +1 ; 
     //SELECT LAST_INSERT_ID() AS id; 
     echo 'a'; 
    }); 


Flight::start(); 
?> 
+0

Musimy zobaczyć metodę 'query'. –

+0

Czy używasz pętli lub wywołuję tę samą metodę 3 razy? – Justinas

+0

jest to standardowa metoda zapytań PDO w php i użyciu ramowym. –

Odpowiedz

Powiązane problemy