• Willkommen im Zend Framework Forum

    ZF1 Zend Framework 1 + ZF2 Zend Framework 2

    Das Zend Framework Forum ist seit 2006 die erste Anlaufstelle für Zend Framework Entwickler in Deutschland. Mit über 70.000 Beiträgen und einer steigenden Nutzerzahl bietet das Forum hilfreiche Themen und ZF-Tutorials für professionelle Entwickler, fortgeschrittene Programmierer sowie Zend Framework Einsteiger.
    Wenn dies Dein erster Besuch in der Zend Framework Community ist, lies bitte zuerst die Hilfe - FAQ durch. Du musst Dich registrieren, bevor Du Beiträge verfassen kannst. Klicke oben auf 'Registrieren', um die Registrierung zu starten. Du kannst auch jetzt schon Beiträge lesen. Hier im Forum findest Du die Zend Framework Hilfe, die Du suchst!

    Grüße an alle Zend Framework Entwickler. Das Team vom Zend Framework Forum!

    Drupal Agentur

Select von leeren Feldern

Frau Bauer

New member
Hallo,

ich habe folgendes Model:

PHP:
namespace Speedy\Model;

use Zend\Db\TableGateway\AbstractTableGateway;
use Zend\Db\TableGateway\TableGateway;

class ReportAssignmentTable extends AbstractTableGateway {
   
   
   protected $_tableGateway;
   
   public function __construct( TableGateway $reportAssignmentTableGateway ) {
      $this->_tableGateway = $reportAssignmentTableGateway;
   }
   
   public function getTableGateway() {
      return $this->_tableGateway;
   }
   
   public function fetchReportIdsBySuperAccountName( SuperAccount $superAccount ) {
      $resultSet = $this->getTableGateway()->select( array(
                                                        'SuperAccountName' => $superAccount->getSuperAccountName(),
                                                     ) );
      
      return $resultSet;
   }
   
   public function fetchReportIdByAndSuperAccountName( ReportAssignment $reportAssignment ) {
      $resultSet = $this->getTableGateway()->select( array(
                                                        'ReportID'         => $reportAssignment->getReportId(),
                                                        'SuperAccountName' => $reportAssignment->getSuperAccountName(),
                                                     ) );
      $row       = $resultSet->current();
      
      return $row;
   }
}
Nun möchte ich allerdings auch alle Zeilen haben, in denen ein Nullwert für "SuperAccountName" steht.

Ich habe schon probiert im Array eine OR-Bedingung hizuzufügen, also:
PHP:
'SuperAccountName' => $reportAssignment->getSuperAccountName() or ''
Leider bringt das nicht den gewünschten Erfolg.

Gibt es für dieses Problem eine simple Lösung, ohne, dass ich meine Anwendung komplett umstricken muss?

Danke
 

Kaiuwe

Super-Moderator
PHP:
class ReportAssignmentTable extends AbstractTableGateway {
   protected $_tableGateway;
   
   public function __construct( TableGateway $reportAssignmentTableGateway ) {
      $this->_tableGateway = $reportAssignmentTableGateway;
   }
}
Was ist das???

Du erweiterst „AbstractTableGateway“ und übergibst dann aber im Konstruktur nochmals ein „TableGateway“-Objekt? Ergibt das für dich einen Sinn?!
 

Kaiuwe

Super-Moderator
Ich habe schon probiert im Array eine OR-Bedingung hizuzufügen, also:
PHP:
'SuperAccountName' => $reportAssignment->getSuperAccountName() or ''
Leider bringt das nicht den gewünschten Erfolg.
Weil dies auch absolut geraten ist! Frau Bauer, schon so lange hier im Forum und schon so viel Zeit mit dem ZF verbracht und dann das…! ;)

In einem „TableGateway“-Klasse geht folgendes:
PHP:
$select = $this->getSql()->select();

$select->where->nest()
        ->isNull('SuperAccountName')
        ->or
        ->equalTo('SuperAccountName', $superAccountName)
        ->unnest()
        ->equalTo('ReportID', $reportId);

$resultSet = $this->selectWith($select);
Oder:
PHP:
$resultSet = $this->select(
    function (\Zend\Db\Sql\Select $select) use ($superAccountName, $reportId) {
        $select->where->nest()
            ->isNull('SuperAccountName')
            ->or
            ->equalTo('SuperAccountName', $superAccountName)
            ->unnest()
            ->equalTo('ReportID', $reportId);
    }
);
 

Frau Bauer

New member
Weil dies auch absolut geraten ist! Frau Bauer, schon so lange hier im Forum und schon so viel Zeit mit dem ZF verbracht und dann das…! ;)
Zuerst einmal (wieder) herzlichen Dank für deine entscheidenden Hinweise. Geraten ist es in der Tat. Ist doch aber eigentlich naheliegend, oder?

Du erweiterst „AbstractTableGateway“ und übergibst dann aber im Konstruktur nochmals ein „TableGateway“-Objekt? Ergibt das für dich einen Sinn?!
Jetzt, wo du mich darauf hinweist. Nein, natürlich überhaupt nicht. Die Table Klassen stammen noch aus dem Album-Beispiel aus der release-Ära des ZF2. Vielleicht hat das da mal so dringestanden. Möchte ich jetzt aber auch nicht vertiefen ;-)

Deine Beispiele probiere ich gleich mal in die Tat umzusetzten. Leider habe ich wohl etwas defizite beim Suchen in der Doku. So wäre ich ohne dich niemals darauf gekommen, nach der nest()-Methode zu suchen.
 

Kaiuwe

Super-Moderator
Die Table Klassen stammen noch aus dem Album-Beispiel aus der release-Ära des ZF2. Vielleicht hat das da mal so dringestanden. Möchte ich jetzt aber auch nicht vertiefen
Nein, denn ein „TableGateway“ in einem „TableGateway“ ergibt so absolut keinen Sinn. Folgende Änderung reicht:

PHP:
use Zend\Db\Adapter\AdapterInterface;

class ReportAssignmentTable extends AbstractTableGateway
{
   public function __construct(AdapterInterface $adapter) {
        $this->table   = 'my_table';
        $this->adapter = $adapter;

        $this->initialize();
    }

    public function fetchReportIdsBySuperAccountName( SuperAccount $superAccount ) {
      return $this->select(['SuperAccountName' => $superAccount->getSuperAccountName()]);
   }

   // …
}
Leider habe ich wohl etwas defizite beim Suchen in der Doku. So wäre ich ohne dich niemals darauf gekommen, nach der nest()-Methode zu suchen.
Du bekommst mit der Methode „getSql“ ein „Zend\Db\Sql\Select“ und dies ist unter „zend-db – SQL Abstraction“ dokumentiert. Dort findest du auch das Beispiel mit „nest“ und „unnest“:

Code:
SELECT * WHERE (column1 is null or column1 = 2) AND (column2 = 3)
 
Oben