0

このようなクエリを作成する場所、どうすればよいですか?

SELECT * FROM hotels WHERE name LIKE '%mykey%' AND country_id = '12'

私はそうしましたが、次のことをしてはなりません:

$select = $this->sql->select();
$select->from(self::TABLE);  

if ($params['key'])
{
   $where['where'] = new \Zend\Db\Sql\Predicate\Like('name', '%'.$params['key'].'%');
}

if($params['country_id'])
{
  $where['where'] = array(
      'country_id' => $params['country_id']
  );
}

$select->where($where['where']);
$select->order('id DESC');
$statement = $this->sql->prepareStatementForSqlObject($select);
return $statement->execute();

クエリの動作を変更するには、if ステートメントを作成する必要があります。どのようにできるのか?

4

1 に答える 1