1

重複の可能性:
ページネーション後に CakePHP Web サイトがクラッシュする

機能するページがありましたが、ページネーションの機能を追加することにしました。そのページで機能し、別のページにコピーしようとすると、pdo データベース エラーが発生します。Relationship.sender_id変数が存在しないと言っています。

次をrelationship含むテーブルがあります-id, sender_id, receiver_id, expiry_date,active

ここに関数のコードがあります

    public function index_admin(){

    //retrieve Account Id of current User       
    $accountid=$this->Auth->user('account_id');

    //Conditions
    $conditions=array(
    "OR"=> array(
        'Relationship.sender_id' => $accountid,
        'Relationship.receiver_id' => $accountid)
    );

    //Find all Relationships where receiver_id = accountid
    $relationships=$this->Relationship->find('all', array(
    'conditions' => $conditions));


    $compName = $this->Account->field('account_name', array('id' => 'Relationship.id'));

    $this->paginate = array(
    'limit' => 10,
    'conditions'=> $conditions);

    $this->set('accountid', $accountid); 
    $this->set('relationship', $this->paginate());  

    $this->set('compName', $compName);  
}

これは本当に私を投げました、どんな助けもいただければ幸いです。

これは、コードが作成する sql クエリです

SELECT `Relationship`.`id`, `Relationship`.`sender_id`, `Relationship`.`receiver_id`,
 `Relationship`.`active`, `Relationship`.`requested`, `Relationship`.`expiry_date`, 
`ReceiverAccount`.`id`, `ReceiverAccount`.`street`, `ReceiverAccount`.`city`, 
`ReceiverAccount`.`postcode`, `ReceiverAccount`.`state`, `ReceiverAccount`.`country`,
 `ReceiverAccount`.`active`, `ReceiverAccount`.`account_name`, `ReceiverAccount`.`abn`,
 `SenderAccount`.`id`, `SenderAccount`.`street`, `SenderAccount`.`city`, 
`SenderAccount`.`postcode`, `SenderAccount`.`state`, `SenderAccount`.`country`, 
`SenderAccount`.`active`, `SenderAccount`.`account_name`, `SenderAccount`.`abn` 
FROM 
`pra`.`relationships` AS `Relationship` LEFT JOIN 
`pra`.`accounts` AS `ReceiverAccount` ON (
`Relationship`.`receiver_id` = `ReceiverAccount`.`id`) LEFT JOIN 
`pra`.`accounts` AS `SenderAccount` ON (
`Relationship`.`sender_id` = `SenderAccount`.`id`) WHERE (
(`Relationship`.`sender_id` = 2) OR (`Relationship`.`receiver_id` = 2))

ページネーションをコメントアウトした後に $relationships をデバッグすると、次の出力が得られます

array(
    (int) 0 => array(
        'Relationship' => array(
            'id' => '5',
            'sender_id' => '3',
            'receiver_id' => '2',
            'active' => false,
            'requested' => false,
            'expiry_date' => '2012-05-09'
        ),
        'ReceiverAccount' => array(
            'id' => '2',
            'street' => '50 Simmington Circuit',
            'city' => 'Greenvale',
            'postcode' => '3059',
            'state' => 'VIC',
            'country' => 'Australia',
            'active' => true,
            'account_name' => 'Kialla Transport (Operations) Pty Ltd',
            'abn' => '2147483647'
        ),
        'SenderAccount' => array(
            'id' => '3',
            'street' => '31 Simmington Circuit',
            'city' => 'Greenvale',
            'postcode' => '3059',
            'state' => 'VIC',
            'country' => 'Australia',
            'active' => true,
            'account_name' => 'MGD Kialla Pty Ltd',
            'abn' => '2147483647'
        )
    ),
4

1 に答える 1

1

行を削除:

$this->paginate = array(
'limit' => 10,
'conditions'=> $conditions);

Relationship コントローラーの上部に変数を追加します。

public $paginate = array(
  'Relationship' = > array(
    'limit' => 10)
   )
);

次に試してください:

$this->set('relationship', $this->paginate('Relationship', $conditions));  

これで問題は解決するはずです...

于 2012-09-18T09:16:21.583 に答える