ti-enxame.com

Como escrever uma instrução Select Select?

Este Método para criar uma subconsulta usando o JDatabase fornece algumas ótimas informações e acho que seria benéfico ter um método de subconsulta acordado documentado. Me deparei com isso porque estou querendo fazer a mesma coisa, mas como uma instrução de inserção. O mais próximo que cheguei foi de toda a tabela replicada porque, por algum motivo, continuo perdendo as colunas.

$query = $db->getQuery(true);
$pre = $db->getQuery(true);

// Insert columns.
$columns = array('user_id', 'title', 'ordering', 'published', 'description');

$now = $query->currentTimestamp();
// Insert values.

$pre->insert($db->qn('#__table'))->columns($db->qn($columns));


// Prepare the insert query.
$query->select(array(
                    $db->q('') . ' AS id',
                    $db->qn('user_id'),
                    $db->qn('c.name', 'title'),
                    $db->q('1') . ' AS published',
                    $db->q('') . ' AS ordering',
                    $db->q('') . ' AS created_by',
                    $now .  ' AS created_on',
                    $db->q('') . ' AS modified_by',
                    $db->q('') . ' AS modified_on',
                    )
            )
            ->from($db->qn('#__other_table', 'c'));

    $query = $pre . $query ;

    // Set the query using our newly populated query object and execute it.
    $db->setQuery($query);

    $db->execute();
4
poproar

Embora essa seja uma pergunta antiga, pode ser útil para outras pessoas. Aqui está a consulta de inserção por seleção usando o JDatabase.

Crie uma consulta de seleção usando JDatabase

$querySelect = $db->getQuery(true)
  ->select('id, title')
  ->from('sometable');

Agora sua consulta de inserção

$queryInsert = $db->getQuery(true)
  ->insert('anothertable')
  ->columns($db->qn(array('id','title')))
  ->values($querySelect)

Espero que isto ajude.

2
Nagarjun

Você precisa digitar quais valores deseja inserir

$pre->insert($db->qn('#__table'))->columns($db->qn($columns))->values(here values);
4
turson