Ir para o conteúdo
  • Revista PROGRAMAR: Já está disponível a edição #60 da revista programar. Faz já o download aqui!

adanielgp

passar uma query(sql) para um array

Mensagens Recomendadas

adanielgp

Boa noite,

Como passo uma query para um array

com esta query:

SQL= Select cod, nome, morada from aluno join aula on aula.codaluno=aluno.cod where aula.id=10 order by aluno.nome

colocar num array:

array['Select']=cod, nome, morada

array['from']= aluno join aula on aula.codaluno=aluno.cod

array['where']= aula.id=10

array['order by']= aluno.nome

Editado por yoda

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
pikax

nao percebi o que queres, podes explicar melhor?


Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
adanielgp

tenho um query e quero dividir em partes ficando com um array.mas a divisão é por SELECT WHERE FROM...

tipo um split_sql

Editado por adanielgp

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
pikax

basta implementar o que escreveste em cima e depois juntar, mas tens que acrescentar as palavras reservadas do SQL(SELECT,FROM,WHERE, ORDER BY).


Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
HappyHippyHippo

function explode2($delimiter, $string, $limit = null)
{
   /* default explode function behavior */
   if (!is_array($delimiter))
       return explode($delimiter, $string, $limit);

   /* limit argument parsing */
   if (!is_null($limit)) {
       $limit = (int)$limit;
       if ($limit == 0 || $limit == 1)
           return array($string);
   }

   /* first delimiter search cycle */
   $index = strlen($string) + 1;
   $hit = '';
   foreach ($delimiter as $part) {
       $strpos = strpos($string, $part);
       if (($strpos !== false) && ($strpos < $index)) {
           $index = $strpos;
           $hit = $part;
       }
   }

   /* string split in head and tail */
   if ($index < 0 || $hit == '') {
       $head = $string;
       $tail = '';
   } else {
       $head = substr($string, 0, $index);
       $tail = substr($string, $index + strlen($hit));
   }

   /* limit with null value parsing */
   if (is_null($limit)) {
       if ($tail != '')
           return array_merge(array($head), explode2($delimiter, $tail));
       return array($head);
   }

   /* position limit value parsing */
   if ($limit > 0) {
       if ($tail != '')
           return array_merge(array($head), explode2($delimiter, $tail, $limit - 1));
       return array($head);
   }

   /* negative limit value parsing */
   if ($tail == '')
       return -1;

   $remain = explode2($delimiter, $tail, $limit);

   if (is_int($remain) && $remain > $limit)
       return $remain - 1;
   if (!is_array($remain))
       return array($head);
   return array_merge(array($head), $remain);
}

$sql = 'select cod, nome, morada from aluno join aula on aula.codaluno=aluno.cod where aula.id=10 order by aluno.nome';
$result = explode2(array('select', 'from', 'where', 'order by'), $sql);
print_r($result);

ou para pessoas que gostem de soluções mais inteligentes :

$sql = 'select cod, nome, morada from aluno join aula on aula.codaluno=aluno.cod where aula.id=10 order by aluno.nome';
$result = preg_split('/select|from|where|order by/i', $sql);
print_r($result);

simples não é :D

-------------------

ps : é comportamento normal do standard explode aparecer o primeiro elemento vazio como no caso apresentado

Editado por HappyHippyHippo

IRC : sim, é algo que ainda existe >> #p@p

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites

Crie uma conta ou ligue-se para comentar

Só membros podem comentar

Criar nova conta

Registe para ter uma conta na nossa comunidade. É fácil!

Registar nova conta

Entra

Já tem conta? Inicie sessão aqui.

Entrar Agora

×

Aviso Sobre Cookies

Ao usar este site você aceita os nossos Termos de Uso e Política de Privacidade. Este site usa cookies para disponibilizar funcionalidades personalizadas. Para mais informações visite esta página.