Como atribuir um valor para variável com um resultado de uma select

02/12/2011

0

Bom dia,

Favor como posso declarar uma variável e a mesma assuma o valor de uma consulta (select).

Estou fazendo da seguinte forma.

V_CAPACIDADE := TO_NUMBER(SELECT MIN (CAPACIDADE_ALUNO) FROM
(SELECT S.CAPACIDADE_SALA - COUNT(T.QUANTIDADE_DE_ALUNOS) AS CAPACIDADE_ALUNO
FROM TURMA T INNER JOIN SALA S
ON T.CODIGO_SALA = S.CODIGO_SALA
GROUP BY S.CAPACIDADE_SALA,T.QUANTIDADE_DE_ALUNOS
)A
WHERE CAPACIDADE_ALUNO > 0);

Dessa forma está correta ou há outra técnica que eu poderia utilizar. Porque eu fiquei com dúvida das aspas simples que eu utilizei e quando é executado sem essas aspas ocorre um erro.
Alberto Amaral.

Alberto Amaral.

Responder

Posts

02/12/2011

Marco Pinheiro

A variavel tem que ser declarada assim:

SELECT MIN (CAPACIDADE_ALUNO) into V_CAPACIDADE
FROM (SELECT S.CAPACIDADE_SALA - COUNT(T.QUANTIDADE_DE_ALUNOS) AS CAPACIDADE_ALUNO
FROM TURMA T INNER JOIN SALA S ON T.CODIGO_SALA = S.CODIGO_SALA
GROUP BY S.CAPACIDADE_SALA,T.QUANTIDADE_DE_ALUNOS)A
WHERE CAPACIDADE_ALUNO > 0

Att.,

Marco.
Responder

03/12/2011

Alberto Amaral.

Valeu Marco

Estou com outro problema fui executar a trigger e apareceu o seguinte erro:

ERRO na linha 1:
ORA-06502: PL/SQL: erro numérico ou de valor : erro de conversão de número em carácter
ORA-06512: na SCOTT.PROFESSOR_TURMA, linha 5
ORA-04088: erro durante a execução do trigger SCOTT.PROFESSOR_TURMA

Abraços
Responder

06/12/2011

Marco Pinheiro

Talvez você deva converter de TO_NUMBER para TO_CHAR. Quando você faz concatenações o padrão é string.

Veja se tem algum numerico concatenando com string.

Att.,

Marco.
Responder

APRENDA A PROGRAMAR DO ZERO AO PROFISSIONAL

Assitir aula

Saiba por que programar é uma questão de
sobrevivência e como aprender sem riscos

Assistir agora

Utilizamos cookies para fornecer uma melhor experiência para nossos usuários, consulte nossa política de privacidade.

Aceitar