【问题标题】:Query works in PLSQL Developer but doesn't in SQL Developer查询在 PLSQL Developer 中有效,但在 SQL Developer 中无效
【发布时间】:2016-05-19 18:50:31
【问题描述】:

所以,我有一个让我发疯的查询。出于某种疯狂的原因,查询运行并在 PLSQL Developer 上带来了所需的输出,但在 SQL Developer 上却没有!据我所知,完全相同的查询应该适用于两者,而不仅仅是一个或另一个。不是我团队中的每个人都有 PLSQL Dev,所以它必须同时在两者上工作。此查询还显示了我的 BI 应用程序上的不同行为。有没有人见过这种疯狂的行为?

这是查询:

with t1 as (
SELECT
  case  when CLG_STATUS.NM_STATUS in ('1 - ATIVO','5 - BLOQUEADO','7 - AGUARDANDO AUTENTICAÇÃO') then 'LG Club Member'
    else 'Non  Member' 
  end membership,
  Round(
    Round(SUM(NVL(CASE WHEN CLG_VENDA.CD_TP_VENDA = 'D' THEN -1*CLG_VENDA.QTD_VENDA ELSE CLG_VENDA.QTD_VENDA END,0)), 1) 
    /
   Count(distinct CLG_PARTICIPANTE.ID)
  , 1) as average_sales ,
  Round(
    SUM(NVL(CASE WHEN CLG_VENDA.CD_TP_VENDA = 'D' THEN -1*CLG_VENDA.QTD_VENDA ELSE CLG_VENDA.QTD_VENDA END,0))
  , 1) as sellout, 
  Count(distinct CLG_PARTICIPANTE.ID)
  as "qty members"
FROM
  CLG_VENDA_PONTO,
  CLG_PARTICIPANTE,
  CLG_STATUS,
  CLG_VENDA,
  CLG_CARGO  CLG_CARGO_VENDA,
  CLG_CANAL  CLG_CANAL_VENDA,
  CLG_REDE  CLG_REDE_VENDA,
  CLG_PRODUTO,
  CLG_TP_MOVIMENTO,
  DIM_PERIOD_DAY  PERIOD_VENDA_DATA,
  CLG_LOJA  CLG_LOJA_VENDA
WHERE
  ( CLG_VENDA_PONTO.ID_VENDA=CLG_VENDA.ID(+)  )
  AND  ( CLG_VENDA_PONTO.ID_PROD=CLG_PRODUTO.ID(+)  )
  AND  ( CLG_VENDA_PONTO.ID_CARGO=CLG_CARGO_VENDA.ID  )
  AND  ( CLG_LOJA_VENDA.ID=CLG_VENDA_PONTO.ID_LOJA  )
  AND  ( CLG_REDE_VENDA.ID=CLG_LOJA_VENDA.ID_REDE  )
  AND  ( CLG_CANAL_VENDA.ID=CLG_VENDA_PONTO.ID_CANAL  )
  AND  ( CLG_PARTICIPANTE.ID_LOJA=CLG_LOJA_VENDA.ID  )
  AND  ( CLG_LOJA_VENDA.ID_REDE=CLG_REDE_VENDA.ID  )
  AND  ( CLG_PARTICIPANTE.ID=CLG_VENDA_PONTO.ID_PARTCPTE  )
  AND  ( CLG_VENDA_PONTO.ID_TP_MOVIMENTO=CLG_TP_MOVIMENTO.ID  )
  AND  ( CLG_STATUS.ID=CLG_PARTICIPANTE.ID_STATUS  )
  AND  ( CLG_VENDA_PONTO.DATA_VENDA=PERIOD_VENDA_DATA.YYYYMMDD  )
  AND  ( CLG_CARGO_VENDA.NM_CARGO = '5 - VENDEDOR' OR CLG_VENDA.ID_CARGO = 8  )
  AND  
  (
   CLG_PRODUTO.NM_PRODUTO  NOT IN  ( 'M4338 - FRETE','R39745 - FRETE SOBRE VENDAS'  )
   AND
   CLG_TP_MOVIMENTO.NM_MOVIMENTO  IN  ( '1 - VENDA','3 - DEVOLUCAO'  )
   AND
   CLG_REDE_VENDA.NM_REDE  =  '21540901 - RABELO'
   AND
   PERIOD_VENDA_DATA.YYYYMMDD_DATE  BETWEEN  to_date('01-01-2013', 'DD-MM-YYYY')  AND  to_date('31-12-2013', 'DD-MM-YYYY')
   AND
   CLG_CANAL_VENDA.NM_CANAL  IN  ('1 - VAREJO')
   AND
   CLG_PRODUTO.FG_MAPEADO  IN  ( 'SIM'  )
  )
GROUP BY
  case  when CLG_STATUS.NM_STATUS in ('1 - ATIVO','5 - BLOQUEADO','7 - AGUARDANDO AUTENTICAÇÃO') then 'LG Club Member'
    else 'Non  Member' 
  end
), t2 as (
SELECT
  case  when CLG_STATUS.NM_STATUS in ('1 - ATIVO','5 - BLOQUEADO','7 - AGUARDANDO AUTENTICAÇÃO') then 'LG Club Member'
    else 'Non  Member' 
  end membership,
  Round(
    Round(SUM(NVL(CASE WHEN CLG_VENDA.CD_TP_VENDA = 'D' THEN -1*CLG_VENDA.QTD_VENDA ELSE CLG_VENDA.QTD_VENDA END,0)), 1) 
    /
   Count(distinct CLG_PARTICIPANTE.ID)
  , 1) as average_sales ,
  Round(
    SUM(NVL(CASE WHEN CLG_VENDA.CD_TP_VENDA = 'D' THEN -1*CLG_VENDA.QTD_VENDA ELSE CLG_VENDA.QTD_VENDA END,0))
  , 1) as sellout, 
  Count(distinct CLG_PARTICIPANTE.ID)
  as "qty members" 
FROM
  CLG_VENDA_PONTO,
  CLG_PARTICIPANTE,
  CLG_STATUS,
  CLG_VENDA,
  CLG_CARGO  CLG_CARGO_VENDA,
  CLG_CANAL  CLG_CANAL_VENDA,
  CLG_REDE  CLG_REDE_VENDA,
  CLG_PRODUTO,
  CLG_TP_MOVIMENTO,
  DIM_PERIOD_DAY  PERIOD_VENDA_DATA,
  CLG_LOJA  CLG_LOJA_VENDA
WHERE
  ( CLG_VENDA_PONTO.ID_VENDA=CLG_VENDA.ID(+)  )
  AND  ( CLG_VENDA_PONTO.ID_PROD=CLG_PRODUTO.ID(+)  )
  AND  ( CLG_VENDA_PONTO.ID_CARGO=CLG_CARGO_VENDA.ID  )
  AND  ( CLG_LOJA_VENDA.ID=CLG_VENDA_PONTO.ID_LOJA  )
  AND  ( CLG_REDE_VENDA.ID=CLG_LOJA_VENDA.ID_REDE  )
  AND  ( CLG_CANAL_VENDA.ID=CLG_VENDA_PONTO.ID_CANAL  )
  AND  ( CLG_PARTICIPANTE.ID_LOJA=CLG_LOJA_VENDA.ID  )
  AND  ( CLG_LOJA_VENDA.ID_REDE=CLG_REDE_VENDA.ID  )
  AND  ( CLG_PARTICIPANTE.ID=CLG_VENDA_PONTO.ID_PARTCPTE  )
  AND  ( CLG_VENDA_PONTO.ID_TP_MOVIMENTO=CLG_TP_MOVIMENTO.ID  )
  AND  ( CLG_STATUS.ID=CLG_PARTICIPANTE.ID_STATUS  )
  AND  ( CLG_VENDA_PONTO.DATA_VENDA=PERIOD_VENDA_DATA.YYYYMMDD  )
  AND  ( CLG_CARGO_VENDA.NM_CARGO = '5 - VENDEDOR' OR CLG_VENDA.ID_CARGO = 8  )
  AND  
  (
   CLG_PRODUTO.NM_PRODUTO  NOT IN  ( 'M4338 - FRETE','R39745 - FRETE SOBRE VENDAS'  )
   AND
   CLG_TP_MOVIMENTO.NM_MOVIMENTO  IN  ( '1 - VENDA','3 - DEVOLUCAO'  )
   AND
   CLG_REDE_VENDA.NM_REDE  =  '21540901 - RABELO'
   AND
   PERIOD_VENDA_DATA.YYYYMMDD_DATE  BETWEEN  add_months(to_date('01-01-2013', 'DD-MM-YYYY'), -12)  AND  add_months(to_date('31-12-2013', 'DD-MM-YYYY'), -12)
   AND
   CLG_CANAL_VENDA.NM_CANAL  IN  ('1 - VAREJO')
   AND
   CLG_PRODUTO.FG_MAPEADO  IN  ( 'SIM'  )
  )
GROUP BY
  case  when CLG_STATUS.NM_STATUS in ('1 - ATIVO','5 - BLOQUEADO','7 - AGUARDANDO AUTENTICAÇÃO') then 'LG Club Member'
    else 'Non  Member' 
  end
)
select t1.*, coalesce((t1.average_sales - t2.average_sales) / t2.average_sales, 0)    as variation
from t1 join t2 on t1.membership = t2.membership

在 SQL Developer 上显示如下:

ORA-00928: missing SELECT keyword
00928. 00000 -  "missing SELECT keyword"

我在这里完全不知所措。查询如何在一个工具而不是另一个工具上解析?我尝试在网上搜索,但无济于事。 提前致谢!

【问题讨论】:

  • “不起作用”如何
  • 对不起,刚刚更新这里,它给出了一个解析错误。这是最让我惊讶的,因为完全相同的查询,复制和粘贴,在 plsql 开发人员中工作
  • @RaoniMedinilha 嗯,您可以尝试将所有非 ASCII 字符更改为 ASCII 对应字符吗?只是为了排除字符编码设置
  • @micklesh 我可以这样做,但是我的大多数查询都涉及非 ASCII 字符,因为它是我的语言的一部分,而且我以前从未遇到过这种问题,有些我是对此问题持怀疑态度。
  • 可能是SQL Developer的版本太旧了。否则将其重写为良好的旧子选择。

标签: oracle oracle-sqldeveloper plsqldeveloper


【解决方案1】:

可能是线,

    /

SQL Plus 本身使用/ 来标记一个sql 查询的结束,SQL Developer 很可能紧随其后。但是,前面的空格可能会改变含义,所以这可能不是问题。

为了检验这个假设,将/ 移到前一行。改变

    Round(SUM(NVL(CASE WHEN CLG_VENDA.CD_TP_VENDA = 'D' THEN -1*CLG_VENDA.QTD_VENDA ELSE CLG_VENDA.QTD_VENDA END,0)), 1) 
    /
   Count(distinct CLG_PARTICIPANTE.ID)

    Round(SUM(NVL(CASE WHEN CLG_VENDA.CD_TP_VENDA = 'D' THEN -1*CLG_VENDA.QTD_VENDA ELSE CLG_VENDA.QTD_VENDA END,0)), 1) /
   Count(distinct CLG_PARTICIPANTE.ID)

如果这是问题所在,则需要将其重新格式化为对您有用的东西,而不是让/ 单独一行。

【讨论】:

  • 那么我会用什么作为除法符号呢?
  • @RaoniMedinilha 他只是将除法符号移到了上面的行
  • 看在皮特的份上! oracle 不能使用其他符号代替除号吗?一旦我这样做了,查询就开始正常工作。我简直不敢相信我因此失去了一整天的工作日非常感谢香农!
猜你喜欢
  • 2019-12-06
  • 1970-01-01
  • 2013-08-11
  • 2020-06-26
  • 2013-01-24
  • 2013-04-03
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多