0

私はこの関数を作成しました:

<?php

$pdo_db = new PDO( 'mysql:host=' . $db_host . ';dbname=' . $db_name, $db_user_name, $db_password );

function qlist_pdo( $fields, $tables, $where_fields='', $where_values='', $order='', $limit='' ) {

GLOBAL $pdo_db; // ignore this, it will be in class later. This is just for test purposes

if ( $order ) $order = ' ORDER BY ' . $order;
if ( $limit ) $limit = ' LIMIT ' . $limit; 

if ( is_array( $where_fields ) && is_array( $where_values ) && isset( $where_fields ) && isset( $where_values ) ) {

    if ( sizeof( $where_fields ) != sizeof( $where_values ) ) {
        die( "Query error: where <strong>field</strong> count doesn't match <strong>value</strong> count!" );
    } else {

        $where = ' WHERE ';
        foreach( $where_fields as $key => $value ) {
            $where .= $key . ' ' . $value . '=? ';
        }
        $where = substr( $where, 0, -1 );

        echo $query = "SELECT " . $fields . " FROM " . $tables . $where . $order . $limit;
        $qp = $pdo_db -> prepare( $query );

        foreach ( $where_values as $key => $val ) {
            $qp -> bindParam( $key+1, $val );
        }           

    }

} else {
    echo $query = "SELECT " . $fields . " FROM " . $tables . $order . $limit;
    $qp = $pdo_db -> prepare( $query );
}

$qp -> execute();
$result = $qp -> fetchAll();

return $result;

}

?>

そして私はそれをこのように呼びます:

$result = qlist_pdo( "*", "list", array( '' => 'id', 'OR' => 'id' ), array( '2', '8' ), 'id DESC' );

これは正常に機能しますが、whereパラメーターを設定すると、結果として1行しか表示されません(2行になるはずです)。このようなパラメータなしで呼び出すと、次のようになります。

$result = qlist_pdo( "*", "list", '', '', 'id DESC' );

すべての行を返します。それはなぜですか、そして私は何を間違っているのですか?

生成されたクエリ:

SELECT * FROM list WHERE id=? OR id=? ORDER BY id DESC

生成されたパラメーター:

1, 2
2, 8  

[編集] 2番目のパラメータのみを追加しているようです。これに変更ORするANDと、行がまったく表示されないはずなのに、1つの結果が得られます(ID = 2 AND ID = 8オプションはあり得ないため)。

[EDIT2]クエリログを設定して、考えていたものを取得しました。実際のクエリはSELECT * FROM list WHERE id='8' OR id='8' ORDER BY id DESC

4

2 に答える 2

0

パラメータを文字列として渡しますが、それらは整数です。

別の方法で配列を渡すことをお勧めします。

$result = 
   qlist_pdo( "*", "list", 
   array( '' => 'id', 'OR' => 'id' ), array( 2, 8 ), 'id DESC' );

関数は次のようになります。

function qlist_pdo( $fields, $tables, $where_fields = '', $where_values = '', $order = '', $limit = '' )
{
  if ( $order )
    $order = ' ORDER BY ' . $order;
  if ( $limit )
    $limit = ' LIMIT ' . $limit;

  if ( is_array( $where_fields ) && is_array( $where_values ) && isset( $where_fields ) && isset( $where_values ) ) 
  {

    if ( sizeof( $where_fields ) != sizeof( $where_values ) ) {
      die( "Query error: where <strong>field</strong> count doesn't match <strong>value</strong> count!" );
    } 
    else {

      $where = ' WHERE ';
      $p = 0;
      foreach ( $where_fields as $key => $value ) {
        $where .= $key . ' ' . $value . '= :p' . $p . ' ';
        $p++;
      }
      $where = substr( $where, 0, -1 );

      echo $query = "SELECT " . $fields . " FROM " . $tables . $where . $order . $limit; // . '<br>';
      $qp = $pdo_db->prepare( $query );

      foreach ( $where_values as $key => $val ) {
        $qp -> bindParam( ":p$key", $val, PDO::PARAM_INT );
        //echo ":p$key" . '<br>';
      }

    }

  } 
  else {
    echo $query = "SELECT " . $fields . " FROM " . $tables . $order . $limit;
    $qp = $pdo_db->prepare( $query );
  }
}

出力のコメントを削除すると、結果としてこれが得られます(私には問題ないようです)

SELECT * FROM list WHERE id= :p0 OR id= :p1 ORDER BY id DESC
:p0
:p1
于 2012-10-03T11:47:49.070 に答える
0

うーん、これは奇妙でしたが、パラメーターをバインドするときに ref が必要だったようです。

それ以外の:

foreach ( $where_values as $key => $val ) {

必要だった:

foreach ( $where_values as $key => &$val ) {

理由はわかりませんが、コードに追加する必要があったのは&だけでした。

于 2012-10-04T06:44:21.763 に答える