0

次のようなSQLクエリがあります。

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 モデルを使用する必要があることを忘れていました。それが違いを生むかどうかはわかりません。

4

1 に答える 1

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。私はこの方法を好みますが、それは単なる文体的なものです。

于 2012-09-18T16:39:40.170 に答える