Oracle EBS – Algumas consultas muito úteis

Este é um post originalmente do site genilto.com. Como é de nosso enorme interesse, faremos uma republicação aqui!

Indices_Oracle1Olá, esperamos que estejam todos bem.

Hoje estamos fazendo um post um pouco mais técnico com algumas informações e consultas que são muito úteis no dia a dia de quem trabalha com Oracle EBS.

 

Buscar parâmetros do programa concorrente

Essa consulta retorna a lista de parâmetros de um programa concorrente cadastrado no EBS. Utilizamos muito para montar os Repasses de Tarefas, que são documentos (word mesmo) criados para documentação dos programas que são cadastrados no EBS, como programas concorrentes, forms, executáveis, listas de valores, etc… Ainda achamos meio antiquado, afinal pode-se criar instaladores através do FNDLOAD (Faremos um post sobre isso), mas muitos clientes ainda utilizam essa documentação.
Como no repasse de tarefas se fazia necessário colocar explicitamente todos os parâmetros e muitas vezes são muitos e muitos, criamos essa consulta que facilita e muito a vida, afinal é só executar, copiar e colar no documento.

SELECT end_user_column_name parametro
     , (SELECT flex_value_set_name FROM fnd_flex_value_sets  
WHERE flex_value_set_id = a.flex_value_set_id)  conjunto_valores
     , required_flag obrigatorio
     , display_flag exibido
     , display_size tamanho
     , form_left_prompt prompt
     , srw_param indicacao
     , DECODE(default_type
            , 'C', 'Constante'
            , 'S', 'Instrução SQL'
            , 'P', 'Perfil'
            , 'A', 'Segmento') tipo_default
     , default_value valor_default
     , a.*
  FROM fnd_descr_flex_col_usage_vl a
 WHERE (application_id = 706) -- ID da aplicacao
   AND (descriptive_flexfield_name = '$SRS$.WICDOL')
 ORDER BY column_seq_num

Verificar programas concorrentes que estão rodando

Esta consulta retorna a lista dos concorrentes em execução no momento. É possível consultar outras fases.

SELECT f.request_id
      ,u.user_name
      ,u.description
      ,p.user_concurrent_program_name
      ,f. request_date
      ,f.status_code
      ,f.phase_code
      ,f.actual_start_date
      ,f.actual_completion_date
      ,TRUNC((f.actual_completion_date - 
              f.actual_start_date) * 24 * 60, 2) segundos
      ,f.argument_text
      ,f.resubmit_interval
      ,f.resubmit_interval_unit_code
  FROM fnd_concurrent_requests f, 
       fnd_concurrent_programs_tl p, 
       fnd_user u
 WHERE u.user_id = f.requested_by
   AND f.concurrent_program_id = p.concurrent_program_id
   AND p.language = 'PTB'
   AND f.status_code = 'R'
 ORDER BY f.actual_start_date DESC;

Ações com programas concorrentes

Abaixo algumas ações posíveis via SQL para modificar o status dos concorrentes.

Finalizar um concorrente

UPDATE fnd_concurrent_requests 
SET phase_code='C', 
status_code='X' 
WHERE request_id IN (127862155)

Resubmeter um concorrente

UPDATE fnd_concurrent_requests 
SET phase_code='P',
status_code='I' 
WHERE request_id IN (127862031)

Alterar prioridade de um concorrente

UPDATE fnd_concurrent_requests 
SET priority  = 47 
WHERE request_id IN (81496150) 
AND xs34 phase_code = 'P' 
AND status_code = 'I' 
AND requested_by = 1262;

Buscar a descrição do Status da Ordem e da Linha da Ordem de Venda (FLOW_STATUS_CODE)

Para saber quais os possíveis status da Ordem de Venda ou da Linha da Ordem de venda.

SELECT *
  FROM oe_lookups a
 WHERE a.lookup_type = 'FLOW_STATUS' -- Header
    OR a.lookup_type = 'LINE_FLOW_STATUS' -- Linha

Buscar Lista de Valores onde a tabela é utilizada

Consulta utilizada quando é necessário encontrar uma lista de valores já pronta para algum parâmetro que iremos utilizar num programa concorrente ou até mesmo para uma lista em um flexfield. O que a consulta faz é retornar quais as listas de valores que trazem informações de uma determinada tabela.

SELECT b.flex_value_set_name
     , a.application_table_name
     , a.value_column_name
     , a.value_column_type
     , a.value_column_size
     , a.id_column_name
     , a.id_column_type
     , a.id_column_size
     , a.meaning_column_name
     , a.meaning_column_type
     , a.meaning_column_size
     , a.additional_where_clause
 FROM FND_FLEX_VALIDATION_TABLES  a
    , FND_FLEX_VALUE_SETS b
WHERE a.flex_value_set_id = b.flex_value_set_id
  AND UPPER(APPLICATION_TABLE_NAME) LIKE '%GME_BATCH_HEADER%'

Por hoje é isso. Quem tiver alguma dúvida basta deixar o comentário ou entrar em contato conosco!

Deixe um comentário

O seu endereço de e-mail não será publicado. Campos obrigatórios são marcados com *