[firebase-br] PLAN natural, porque?

omar l m rosa omarrosa em terra.com.br
Qua Jan 24 15:34:18 -03 2007


Fiz dois testes
1) substitui por join - tudo igual
2) substitui um relacionamento para ficar tudo apontando p/ tabela do
select - perdeu o indice da tabela usuarios!!!
3) DDL das tabelas envolvidas

(Uso fb.2.0 vou ver com o fb 1.5)


>>>>>>>>>>>>>>>>>>>>>>>*******************************<<<<<<<<<<<<<<<<<<<<<<
<<<<
primeiro teste: substitui por join ( mesmo resultado)
-----------------------------------------------------
select M.PK_MERCADORIAS,
       M.CODIGO,
       P.STATUS,
       P.CODIGO_PEDIDO,
       M.DESCRICAO,
       P.QUANTIDADE,
       P.PRECO_UNITARIO,
       P.DESCONTO,
       E.LOCALIZACAO,
       U.NOME,
       P.PK_PEDIDOS,
       P.PK_PEDIDOS_MERC,
       P.PK_USUARIOS,
       P.PK_MERC_ESTOQUES,
       P.DATA,
       P.TABELA_PRECOS,
       P.QUANTIDADE * P.PRECO_UNITARIO
from PEDIDOS_MERC P
join MERC_ESTOQUES E on (P.PK_MERC_ESTOQUES = E.PK_MERC_ESTOQUES)
join MERCADORIAS M on (M.PK_MERCADORIAS = E.PK_MERCADORIAS)
/*-----------------------------------------------------===E.================
====== <<<<<<<<<<<<<<*/
join USUARIOS U on (P.PK_USUARIOS = U.PK_USUARIOS)
where P.PK_PEDIDOS = :APK_PEDIDOS
      order by PK_PEDIDOS_MERC

Plan
PLAN SORT (JOIN (M NATURAL, E INDEX (I_MERC_ESTOQUES_1), P INDEX
(FK_PEDIDOS_MERC_1), U INDEX (PK_USUARIOS)))

Adapted Plan
PLAN SORT (JOIN (M NATURAL, E INDEX (I_MERC_ESTOQUES_1), P INDEX
(FK_PEDIDOS_MERC_1), U INDEX (PK_USUARIOS)))

>>>>>>>>>>>>>>>>>>****************************<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
<<<<<<<
>>>>>>>>>>>>>>>>>>****************************<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
<<<<<<<

segundo teste:  (alterei join MERCADORIAS M on (M.PK_MERCADORIAS =
P.PK_MERCADORIAS)

==P.==============-<<<<<<<<<<<<<<<<<<
ou seja todos os joins apontam para a tabela do select

?? perdeu o indice de usuarios "U NATURAL"
----------------------------------------------------------
Plan
PLAN SORT (JOIN (U NATURAL, P INDEX (FK_PEDIDOS_MERC_2), M INDEX
(PK_MERCADORIAS), E INDEX
                        ==================
(PK_MERC_ESTOQUES)))

Adapted Plan
PLAN SORT (JOIN (U NATURAL, P INDEX (FK_PEDIDOS_MERC_2), M INDEX
(PK_MERCADORIAS), E INDEX (PK_MERC_ESTOQUES)))

>>>>>>>>>>>>>>>>>>****************************<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
<<<<<<<
>>>>>>>>>>>>>>>>>>****************************<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
<<<<<<<
>>>>>>>>>>>>>>>>>>****************************<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
<<<<<<<

DDL das tabelas envolvidas:

===========================

SET SQL DIALECT 3;
SET NAMES WIN1252;

CREATE TABLE MERCADORIAS (
    PK_MERCADORIAS             INTEGER NOT NULL,
    CODIGO                     VARCHAR(40) COLLATE WIN_PTBR,
    DESCRICAO                  VARCHAR(100) COLLATE WIN_PTBR,
);
ALTER TABLE MERCADORIAS ADD CONSTRAINT PK_MERCADORIAS PRIMARY KEY
(PK_MERCADORIAS);
CREATE UNIQUE INDEX MERCADORIAS_IDX1 ON MERCADORIAS (CODIGO);

==================================

CREATE TABLE PEDIDOS_MERC (
    PK_PEDIDOS_MERC   INTEGER NOT NULL,
    PK_PEDIDOS        INTEGER,
    PK_MERC_ESTOQUES  INTEGER,
    QUANTIDADE        NUMERIC(10,2),
    PRECO_UNITARIO    DECIMAL(15,2),
    DESCONTO          DECIMAL(15,2),
    DATA              TIMESTAMP,
    PK_USUARIOS       INTEGER,
    PK_HISTORICOS     INTEGER,
    TABELA_PRECOS     TIMESTAMP,
    ESTOQUE_ANT       NUMERIC(10,2),
    CODIGO_PEDIDO     VARCHAR(40) COLLATE WIN_PTBR,
    STATUS            SMALLINT,
    POSICAO_PECA      VARCHAR(10) COLLATE WIN_PTBR,
    PK_MERCADORIAS    INTEGER,
    DESCRICAO_PEDIDO  VARCHAR(100),
    OPCAO_PEDIDO      SMALLINT
);
ALTER TABLE PEDIDOS_MERC ADD CONSTRAINT CHK1_PEDIDOS_MERC CHECK(QUANTIDADE >
0);
ALTER TABLE PEDIDOS_MERC ADD CONSTRAINT CHK2_PEDIDOS_MERC
CHECK(PRECO_UNITARIO > 0);
ALTER TABLE PEDIDOS_MERC ADD CONSTRAINT PK_PEDIDOS_MERC PRIMARY KEY
(PK_PEDIDOS_MERC);
ALTER TABLE PEDIDOS_MERC ADD CONSTRAINT FK_PEDIDOS_MERC_1 FOREIGN KEY
(PK_MERC_ESTOQUES) REFERENCES MERC_ESTOQUES (PK_MERC_ESTOQUES);
ALTER TABLE PEDIDOS_MERC ADD CONSTRAINT FK_PEDIDOS_MERC_2 FOREIGN KEY
(PK_USUARIOS) REFERENCES USUARIOS (PK_USUARIOS);

===========================================

CREATE TABLE MERC_ESTOQUES (
    PK_MERC_ESTOQUES    INTEGER NOT NULL,
    PK_TB_ESTOQUES      INTEGER,
    PK_MERCADORIAS      INTEGER,
    QUANTIDADE          NUMERIC(10,2),
    LOCALIZACAO         VARCHAR(20) COLLATE WIN_PTBR,
    ULTIMA_ENTRADA      TIMESTAMP,
    ULTIMA_SAIDA        TIMESTAMP,
    PK_USUARIOS_ENT     INTEGER,
    PK_USUARIOS_SAI     INTEGER,
    PK_MERC_INVENTARIO  INTEGER,
    STATUS              SMALLINT,
    QTD_PEDIDAS         NUMERIC(10,2)
);
ALTER TABLE MERC_ESTOQUES ADD CONSTRAINT PK_MERC_ESTOQUES PRIMARY KEY
(PK_MERC_ESTOQUES);
CREATE INDEX I_MERC_ESTOQUES_1 ON MERC_ESTOQUES (PK_MERCADORIAS);

=============================

CREATE TABLE USUARIOS (
    PK_USUARIOS           INTEGER NOT NULL,
    NOME                  VARCHAR(50) COLLATE WIN_PTBR,
   );
ALTER TABLE USUARIOS ADD CONSTRAINT PK_USUARIOS PRIMARY KEY (PK_USUARIOS);

=============================

----- Original Message -----
From: "Carlos H. Cantu (TeamFB)" <listas em warmboot.com.br>
To: "FireBase" <lista em firebase.com.br>
Sent: Wednesday, January 24, 2007 11:42 AM
Subject: Re: [firebase-br] PLAN natural, porque?


O fato de vc não estar usando a sintaxe do SQL92 pode estar
prejudicando o optimizador... substitua o WHERE por JOINs e veja se
ele altera o plano.

PS: Muitas variáveis influem da decisão do otimizador de usar um
índice ou não... geralmente ele acerta, mas nem sempre. Pode ser o seu
caso.

[]s
Cantu (Membro do TeamFB - FireBase)
http://www.warmboot.com.br
FireBase - http://www.FireBase.com.br

olmr> O select abaixo está me retornando um plano extranho, pois todas as
colunas
olmr> do where são primary keys, portanto indexadas, e logo ma tabela
mercadorias
olmr> que é a maior!!!!
olmr> (fb 2.0)
olmr> -----------

olmr> select m.pk_mercadorias,
olmr> m.codigo,
olmr> p.status,
olmr> P.CODIGO_PEDIDO,
olmr> m.descricao,
olmr> p.quantidade,
olmr> p.preco_unitario,
olmr> p.desconto,
olmr> e.localizacao,
olmr> u.nome,
olmr> p.pk_pedidos,
olmr> p.pk_pedidos_merc,
olmr> p.pk_usuarios,
olmr> p.pk_merc_estoques,
olmr> p.data,
olmr> p.TABELA_PRECOS,
olmr> p.quantidade * p.preco_unitario
olmr> from mercadorias m, pedidos_merc p, usuarios u, merc_estoques e
olmr> where m.pk_mercadorias = e.pk_mercadorias and
olmr>       p.pk_merc_estoques = e.pk_merc_estoques and
olmr>       p.pk_usuarios = u.pk_usuarios
olmr> ;
olmr> ----------------
olmr> Plan
olmr> PLAN JOIN (M NATURAL, E INDEX (I_MERC_ESTOQUES_1), P INDEX
olmr> (FK_PEDIDOS_MERC_1), U INDEX (PK_USUARIOS))

olmr> Adapted Plan
olmr> PLAN JOIN (M NATURAL, E INDEX (I_MERC_ESTOQUES_1), P INDEX
olmr> (FK_PEDIDOS_MERC_1), U INDEX (PK_USUARIOS))


olmr> ______________________________________________
olmr> FireBase-BR (www.firebase.com.br) - Hospedado em www.locador.com.br
olmr> Para editar sua configuração na lista, use o endereço
olmr> http://mail.firebase.com.br/mailman/listinfo/lista_firebase.com.br
olmr> Para consultar mensagens antigas: http://firebase.com.br/pesquisa


______________________________________________
FireBase-BR (www.firebase.com.br) - Hospedado em www.locador.com.br
Para editar sua configuração na lista, use o endereço
http://mail.firebase.com.br/mailman/listinfo/lista_firebase.com.br
Para consultar mensagens antigas: http://firebase.com.br/pesquisa





Mais detalhes sobre a lista de discussão lista