Подзапрос по формату базы данных Zend

0

Я создал запрос в MYSQL следующим образом:

select subsql.item_id, subsql.uid, subsql.post_date, subsql.uid_prev,
max(workflow_trans.date) AS pre_date

from (
    select item_id, max(date) AS post_date, uid, uid_prev
    from workflow_trans 
    where uid = 'name' and date <= 'date1' and date >= 'date2'
    group by item_id, uid, uid_prev
) AS subsql

left join workflow_trans on subsql.item_id = workflow_trans.item_id and
subsql.uid_prev = workflow_trans.uid and subsql.post_date > workflow_trans.date

where workflow_trans.date is not null
group by subsql.item_id, subsql.uid, subsql.post_date, subsql.uid_prev
order by subsql.post_date

The In перевел его в формат Zend DB следующим образом:

$this->db->select()->from(array("subsql" => $this->db->select()
->from(array($this->_name), array('item_id', 'max(date) AS post_date', 
'uid', 'uid_prev'))
->where("uid = ?", $username)->where("date >= ?", $tgl1)
->where("date <= ?", $tgl2)
->group(array('item_id', 'uid', 'uid_prev'))), 
array('subsql.item_id','subsql.uid',
'subsql.post_date','subsql.uid_prev','max(workflow_trans.date)
as pre_date'))
->joinLeft($this->_name, 'subsql.item_id = workflow_trans.item_id 
and subsql.uid_prev = workflow_trans.uid and subsql.post_date > 
workflow_trans.date')
->where("workflow_trans.date != ?", null)
->group(array('subsql.item_id', 'subsql.uid', 'subsql.post_date',
'subsql.uid_prev'))
->order(array('subsql.post_date'))

Однако модель Zend не могла работать. я был пересмотрен, и сделал 3 изменения, но все-таки что-то не так с форматированием. Свежая пара острых глаз ценится.

ОБНОВЛЕНИЕ ОТВЕТОВ

Привет, ребята, я уже нашел это, под бегущим кодом:

$this->db->select()->from(array("subsql" => $this->db->select()
->from(array($this->_name), array('item_id', 'max(date) AS post_date', 
'uid', 'uid_prev'))
->where("uid = ?", $username)->where("date >= ?", $tgl1)
->where("date <= ?", $tgl2)
->group(array('item_id', 'uid', 'uid_prev'))), 
array('subsql.item_id','subsql.uid','subsql.post_date','subsql.uid_prev'))
->joinLeft(array($this->_name), 'subsql.item_id = workflow_trans.item_id and
subsql.uid_prev = workflow_trans.uid and
subsql.post_date > workflow_trans.date', 
array('max(workflow_trans.date) as pre_date'))
->where("workflow_trans.date is not null")
->group(array('subsql.item_id', 'subsql.uid', 'subsql.post_date',
'subsql.uid_prev'))
->order(array('subsql.post_date'));

Вы должны определить столбец из таблицы объединения в своей собственной функции соединения, и, конечно, я неправильно понял, как обрабатывать нуль.

  • 0
    какая у тебя версия zend и php?
Теги:
subquery
zend-framework
zend-db

1 ответ

1

Если мы говорим о zf3, этот запрос генерирует тот же sql, что и ваш.

$from = $this->getSql()->select('workflow_trans')
                ->columns(['item_id, max(date) AS post_date, uid, uid_prev', new Literal('max(workflow_trans.date) AS pre_date')])
                ->where(['uid = ?' => 'name'])
                ->where(['date <= ?' => 'date1'])
                ->where(['date >= ?' => 'date2'])
                ->group(['item_id', 'uid', 'uid_prev']);

$query = $this->getSql()->select()
                    ->columns(['item_id, uid, post_date, uid_prev'])
                    ->from(['subsql' => $from])
                    ->join('workflow_trans', 'subsql.item_id = workflow_trans.item_id and subsql.uid_prev = workflow_trans.uid and subsql.post_date > workflow_trans.date', [])
                    ->where(new IsNotNull('workflow_trans.date'))
                    ->group(['subsql.item_id', 'subsql.uid', 'subsql.post_date', 'subsql.uid_prev'])
                    ->order('subsql.post_date');

Ещё вопросы

Сообщество Overcoder
Наверх
Меню