2016-06-02 2 views
0
$date = date("Y-m-d"); 
    $prev_date = date('m-d-Y', strtotime($date .' -1 day')); 
    $q = "SELECT `id`, `external_id`, `status`, DATE_FORMAT(from_unixtime(`created`),'%m-%d-%Y') as crt, `extras` 
      FROM `gshuplogs` WHERE DATE_FORMAT(from_unixtime(`created`),'%m-%d-%Y') = '$prev_date' and 
      (BINARY `status` in ('success','DEFERRED') or `status` IS NULL)"; 
    $conn = \Cake\Datasource\ConnectionManager::get('default'); 
    $res = $conn->execute($q)->fetchAll('assoc'); 
    debug($res);exit; 

Этот запрос я написал в MySQL теперь я просто хотел написать в CakePHP 3.CakePHP 3 чувствительны к регистру запроса

Я попытался

$res = $this->Gshuplogs->find()->select([ 
     'id', 'external_id', 'status', 'created' 
    ])->where([ 
     "DATE_FORMAT(from_unixtime(`created`),'%m-%d-%Y')" => $prev_date, 
     'OR' => [ 
      ['LOWER status' => 'success'], 
      ['status' => 'DEFERRED'], 
      ['status IS NULL'] 
     ] 
    ]); 

И

$res = $this->Gshuplogs->find()->select([ 
     'id', 'external_id', 'status', 'created' 
    ])->where([ 
     "DATE_FORMAT(from_unixtime(`created`),'%m-%d-%Y')" => $prev_date, 
     'OR' => [ 
      ['BINARY status' => 'success'], 
      ['status' => 'DEFERRED'], 
      ['status IS NULL'] 
     ] 
    ]); 

Но это ошибка.

Error: SQLSTATE[42000]: Syntax error or access violation: 1064 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '`),'%m-%d-%Y'`) = '06-01-2016' AND (`LOWER` status 'success' OR `status` = 'DEFE' at line 1

+1

Какая ошибка это бросание? – Alex

+0

Hi @Alex здесь ошибка ..! Ошибка: SQLSTATE [42000]: Синтаксическая ошибка или нарушение доступа: 1064 У вас есть ошибка в синтаксисе SQL; проверьте руководство, соответствующее версии вашего сервера MySQL, для правильного синтаксиса для использования рядом с ''), '% m-% d-% Y'') = '06 -01-2016' AND ('LOWER' status 'success' ИЛИ 'status' = 'DEFE' в строке 1 –

+0

Вероятно, просто отсутствующие скобки:' ['LOWER (status)' => 'success'], 'cf. ваше сообщение об ошибке. –

ответ

0

Благодарим за отзыв. Я получил решение.

$date = date("Y-m-d"); 
    $prev_date = date('m-d-Y', strtotime($date .' -1 day')); 

    $res = $this->Gshuplogs->find()->select([ 
     'id', 'external_id', 'status', "created" 
    ])->where([ 
     "FROM_UNIXTIME(`created`,'%m-%d-%Y')" => $prev_date, 
     'OR' => [ 
      ['BINARY(status) in ' => ['success','DEFERRED']], 
      ['status IS NULL'] 
     ] 
    ]); 

    debug($res->toArray());exit; 
Смежные вопросы