2012-09-18 126 views
0

我有一個SQL查詢,如下所示:編寫SQL查詢在PHP

select * from some_table where some_name_id = 
(select some_name_id from some_names where some_name = 'FALL' 
    and some_other_id = 1) 
and year(some_start_date) = 2012 and some_other_id = 1; 

注意,'FALL'和開始日期和some_other_id將要在動態地從我從讀文件送入。我需要的只是在php中寫出這個查詢的幫助。當談到那些東西時,我有些不知所措。仍然讓我的腳溼與PHP。我忘了提及我不得不使用Doctrine模型。不知道這是否有所作爲。

+2

檢查[本教程](http://wiki.hashphp.org/PDO_Tutorial_for_MySQL_Developers)。基本上,您完全按照通常的方式編寫查詢,將佔位符放在需要動態輸入的地方,綁定輸入的實際值,執行。 – DCoder

回答

1

結賬PDO。它比程序化的mysql_命令需要更多的習慣,但完全值得。

$my_id = // whatever; 
$my_name = // whatever; 
$db_obj = new PDO (/* connection string */); 

$query_str = "select * from some_table where some_name_id = 
    (select some_name_id from some_names where some_name = :name 
     and some_other_id = 1) 
    and year(some_start_date) = 2012 and some_other_id = :id"; 
$query_obj = $db_obj->prepare ($query_str); // creates a PDOStatement object 
$query_obj->bindParam(":name", $my_name); // essentially replaces :name with $my_name* 
$query_obj->bindParam(":id", $my_id); // essentially replaces :id with $my_id* 
$query_obj->execute(); // executes the query 
while ($row = $query_obj->fetch (PDO:FETCH_ASSOC)) { 
    /* some code */ 
}; 

注1:在評論中bindParam解釋是方式簡單化。值得關注PDO以及bindParam實際如何工作以獲取更多信息。注意2:很多人喜歡命名$ query_str $query和$ query_obj $result。我更喜歡這種方式,但這只是一種風格。