Probleme de perfs sur une requête

Le
Brigitte
Bonjour,

Comment peut-on expliquer que ces deux requêtes ont un temps d'exécution
totalement différent :

SELECT DISTINCT PROFIL_ID, POSBT.SICOVAM, POSBT.FAIRVALUE, PRIX.THEO,
POS.FAIRVALUE, POSBT.QUANTITY, POSBT.COD_PORT, POSBT.COD_DEVISE, '20070806',
GETDATE()
FROM IMP_VAR_DETAIL_POS_BT_CORRIGE POSBT, REF_PORT_SOURCE_HISTORIQUE RPS,
IMP_SOPH_PRIX PRIX, IMP_VAR_DETAIL_POS_GEN_CORRIGE POS
WHERE RPS.DAT_PRO_UTIL = '20070806'
AND POSBT.DAT_PRO = '20070806'
AND PRIX.DAT_PRO = '20070806'
AND POS.DAT_PRO = '20070806'
AND SOURCE = 'SOPHIS'
AND POSBT.COD_PORT = RPS.COD_PORT
AND POSBT.SICOVAM *= SIC_INSTR
AND POSBT.QUANTITY <> 0
AND POSBT.COD_PORT = POS.COD_PORT
AND POSBT.SICOVAM = POS.SICOVAM
AND POSBT.QUANTITY = POS.QUANTITY

DECLARE @DAT_PRO varchar(8)
SELECT @DAT_PRO = '20070806'

SELECT DISTINCT PROFIL_ID, POSBT.SICOVAM, POSBT.FAIRVALUE, PRIX.THEO,
POS.FAIRVALUE, POSBT.QUANTITY, POSBT.COD_PORT, POSBT.COD_DEVISE, '20070806',
GETDATE()
FROM IMP_VAR_DETAIL_POS_BT_CORRIGE POSBT, REF_PORT_SOURCE_HISTORIQUE RPS,
IMP_SOPH_PRIX PRIX, IMP_VAR_DETAIL_POS_GEN_CORRIGE POS
WHERE RPS.DAT_PRO_UTIL = @DAT_PRO
AND POSBT.DAT_PRO = @DAT_PRO
AND PRIX.DAT_PRO = @DAT_PRO
AND POS.DAT_PRO = @DAT_PRO
AND SOURCE = 'SOPHIS'
AND POSBT.COD_PORT = RPS.COD_PORT
AND POSBT.SICOVAM *= SIC_INSTR
AND POSBT.QUANTITY <> 0
AND POSBT.COD_PORT = POS.COD_PORT
AND POSBT.SICOVAM = POS.SICOVAM
AND POSBT.QUANTITY = POS.QUANTITY

merci

Bonne journée

Brigitte
Vidéos High-Tech et Jeu Vidéo
Téléchargements
Vos réponses
Gagnez chaque mois un abonnement Premium avec GNT : Inscrivez-vous !
Trier par : date / pertinence
Jean-Pierre Riehl
Le #11852821
Bonjour,

Ces 2 requêtes sont-elles appelées depuis une procédure stockée, une
instruction sp_executesql ou depuis une commande préparée ?
L'utilisation de variables locales dans un script peut influer sur
l'optimiseur de requête quand il la compile.


--
Jean-Pierre Riehl
http://blog.djeepy1.net
http://www.bewise.fr


"Brigitte" news:
Bonjour,

Comment peut-on expliquer que ces deux requêtes ont un temps d'exécution
totalement différent :

SELECT DISTINCT PROFIL_ID, POSBT.SICOVAM, POSBT.FAIRVALUE, PRIX.THEO,
POS.FAIRVALUE, POSBT.QUANTITY, POSBT.COD_PORT, POSBT.COD_DEVISE,
'20070806',
GETDATE()
FROM IMP_VAR_DETAIL_POS_BT_CORRIGE POSBT, REF_PORT_SOURCE_HISTORIQUE RPS,
IMP_SOPH_PRIX PRIX, IMP_VAR_DETAIL_POS_GEN_CORRIGE POS
WHERE RPS.DAT_PRO_UTIL = '20070806'
AND POSBT.DAT_PRO = '20070806'
AND PRIX.DAT_PRO = '20070806'
AND POS.DAT_PRO = '20070806'
AND SOURCE = 'SOPHIS'
AND POSBT.COD_PORT = RPS.COD_PORT
AND POSBT.SICOVAM *= SIC_INSTR
AND POSBT.QUANTITY <> 0
AND POSBT.COD_PORT = POS.COD_PORT
AND POSBT.SICOVAM = POS.SICOVAM
AND POSBT.QUANTITY = POS.QUANTITY

DECLARE @DAT_PRO varchar(8)
SELECT @DAT_PRO = '20070806'

SELECT DISTINCT PROFIL_ID, POSBT.SICOVAM, POSBT.FAIRVALUE, PRIX.THEO,
POS.FAIRVALUE, POSBT.QUANTITY, POSBT.COD_PORT, POSBT.COD_DEVISE,
'20070806',
GETDATE()
FROM IMP_VAR_DETAIL_POS_BT_CORRIGE POSBT, REF_PORT_SOURCE_HISTORIQUE RPS,
IMP_SOPH_PRIX PRIX, IMP_VAR_DETAIL_POS_GEN_CORRIGE POS
WHERE RPS.DAT_PRO_UTIL = @DAT_PRO
AND POSBT.DAT_PRO = @DAT_PRO
AND PRIX.DAT_PRO = @DAT_PRO
AND POS.DAT_PRO = @DAT_PRO
AND SOURCE = 'SOPHIS'
AND POSBT.COD_PORT = RPS.COD_PORT
AND POSBT.SICOVAM *= SIC_INSTR
AND POSBT.QUANTITY <> 0
AND POSBT.COD_PORT = POS.COD_PORT
AND POSBT.SICOVAM = POS.SICOVAM
AND POSBT.QUANTITY = POS.QUANTITY

merci

Bonne journée

Brigitte


Brigitte
Le #11852811
Par query analyser.

Merci

Brigitte

"Jean-Pierre Riehl" a écrit :

Bonjour,

Ces 2 requêtes sont-elles appelées depuis une procédure stockée, une
instruction sp_executesql ou depuis une commande préparée ?
L'utilisation de variables locales dans un script peut influer sur
l'optimiseur de requête quand il la compile.


--
Jean-Pierre Riehl
http://blog.djeepy1.net
http://www.bewise.fr


"Brigitte" news:
> Bonjour,
>
> Comment peut-on expliquer que ces deux requêtes ont un temps d'exécution
> totalement différent :
>
> SELECT DISTINCT PROFIL_ID, POSBT.SICOVAM, POSBT.FAIRVALUE, PRIX.THEO,
> POS.FAIRVALUE, POSBT.QUANTITY, POSBT.COD_PORT, POSBT.COD_DEVISE,
> '20070806',
> GETDATE()
> FROM IMP_VAR_DETAIL_POS_BT_CORRIGE POSBT, REF_PORT_SOURCE_HISTORIQUE RPS,
> IMP_SOPH_PRIX PRIX, IMP_VAR_DETAIL_POS_GEN_CORRIGE POS
> WHERE RPS.DAT_PRO_UTIL = '20070806'
> AND POSBT.DAT_PRO = '20070806'
> AND PRIX.DAT_PRO = '20070806'
> AND POS.DAT_PRO = '20070806'
> AND SOURCE = 'SOPHIS'
> AND POSBT.COD_PORT = RPS.COD_PORT
> AND POSBT.SICOVAM *= SIC_INSTR
> AND POSBT.QUANTITY <> 0
> AND POSBT.COD_PORT = POS.COD_PORT
> AND POSBT.SICOVAM = POS.SICOVAM
> AND POSBT.QUANTITY = POS.QUANTITY
>
> DECLARE @DAT_PRO varchar(8)
> SELECT @DAT_PRO = '20070806'
>
> SELECT DISTINCT PROFIL_ID, POSBT.SICOVAM, POSBT.FAIRVALUE, PRIX.THEO,
> POS.FAIRVALUE, POSBT.QUANTITY, POSBT.COD_PORT, POSBT.COD_DEVISE,
> '20070806',
> GETDATE()
> FROM IMP_VAR_DETAIL_POS_BT_CORRIGE POSBT, REF_PORT_SOURCE_HISTORIQUE RPS,
> IMP_SOPH_PRIX PRIX, IMP_VAR_DETAIL_POS_GEN_CORRIGE POS
> WHERE RPS.DAT_PRO_UTIL = @DAT_PRO
> AND POSBT.DAT_PRO = @DAT_PRO
> AND PRIX.DAT_PRO = @DAT_PRO
> AND POS.DAT_PRO = @DAT_PRO
> AND SOURCE = 'SOPHIS'
> AND POSBT.COD_PORT = RPS.COD_PORT
> AND POSBT.SICOVAM *= SIC_INSTR
> AND POSBT.QUANTITY <> 0
> AND POSBT.COD_PORT = POS.COD_PORT
> AND POSBT.SICOVAM = POS.SICOVAM
> AND POSBT.QUANTITY = POS.QUANTITY
>
> merci
>
> Bonne journée
>
> Brigitte



Brigitte
Le #11852801
Pas dans une stored proc

"Jean-Pierre Riehl" a écrit :

Bonjour,

Ces 2 requêtes sont-elles appelées depuis une procédure stockée, une
instruction sp_executesql ou depuis une commande préparée ?
L'utilisation de variables locales dans un script peut influer sur
l'optimiseur de requête quand il la compile.


--
Jean-Pierre Riehl
http://blog.djeepy1.net
http://www.bewise.fr


"Brigitte" news:
> Bonjour,
>
> Comment peut-on expliquer que ces deux requêtes ont un temps d'exécution
> totalement différent :
>
> SELECT DISTINCT PROFIL_ID, POSBT.SICOVAM, POSBT.FAIRVALUE, PRIX.THEO,
> POS.FAIRVALUE, POSBT.QUANTITY, POSBT.COD_PORT, POSBT.COD_DEVISE,
> '20070806',
> GETDATE()
> FROM IMP_VAR_DETAIL_POS_BT_CORRIGE POSBT, REF_PORT_SOURCE_HISTORIQUE RPS,
> IMP_SOPH_PRIX PRIX, IMP_VAR_DETAIL_POS_GEN_CORRIGE POS
> WHERE RPS.DAT_PRO_UTIL = '20070806'
> AND POSBT.DAT_PRO = '20070806'
> AND PRIX.DAT_PRO = '20070806'
> AND POS.DAT_PRO = '20070806'
> AND SOURCE = 'SOPHIS'
> AND POSBT.COD_PORT = RPS.COD_PORT
> AND POSBT.SICOVAM *= SIC_INSTR
> AND POSBT.QUANTITY <> 0
> AND POSBT.COD_PORT = POS.COD_PORT
> AND POSBT.SICOVAM = POS.SICOVAM
> AND POSBT.QUANTITY = POS.QUANTITY
>
> DECLARE @DAT_PRO varchar(8)
> SELECT @DAT_PRO = '20070806'
>
> SELECT DISTINCT PROFIL_ID, POSBT.SICOVAM, POSBT.FAIRVALUE, PRIX.THEO,
> POS.FAIRVALUE, POSBT.QUANTITY, POSBT.COD_PORT, POSBT.COD_DEVISE,
> '20070806',
> GETDATE()
> FROM IMP_VAR_DETAIL_POS_BT_CORRIGE POSBT, REF_PORT_SOURCE_HISTORIQUE RPS,
> IMP_SOPH_PRIX PRIX, IMP_VAR_DETAIL_POS_GEN_CORRIGE POS
> WHERE RPS.DAT_PRO_UTIL = @DAT_PRO
> AND POSBT.DAT_PRO = @DAT_PRO
> AND PRIX.DAT_PRO = @DAT_PRO
> AND POS.DAT_PRO = @DAT_PRO
> AND SOURCE = 'SOPHIS'
> AND POSBT.COD_PORT = RPS.COD_PORT
> AND POSBT.SICOVAM *= SIC_INSTR
> AND POSBT.QUANTITY <> 0
> AND POSBT.COD_PORT = POS.COD_PORT
> AND POSBT.SICOVAM = POS.SICOVAM
> AND POSBT.QUANTITY = POS.QUANTITY
>
> merci
>
> Bonne journée
>
> Brigitte



bruno reiter
Le #11852791
as-tu regardé les plans d'exec, stats time et stats I/O ?

br

"Brigitte" news:
Bonjour,

Comment peut-on expliquer que ces deux requêtes ont un temps d'exécution
totalement différent :

SELECT DISTINCT PROFIL_ID, POSBT.SICOVAM, POSBT.FAIRVALUE, PRIX.THEO,
POS.FAIRVALUE, POSBT.QUANTITY, POSBT.COD_PORT, POSBT.COD_DEVISE,
'20070806',
GETDATE()
FROM IMP_VAR_DETAIL_POS_BT_CORRIGE POSBT, REF_PORT_SOURCE_HISTORIQUE RPS,
IMP_SOPH_PRIX PRIX, IMP_VAR_DETAIL_POS_GEN_CORRIGE POS
WHERE RPS.DAT_PRO_UTIL = '20070806'
AND POSBT.DAT_PRO = '20070806'
AND PRIX.DAT_PRO = '20070806'
AND POS.DAT_PRO = '20070806'
AND SOURCE = 'SOPHIS'
AND POSBT.COD_PORT = RPS.COD_PORT
AND POSBT.SICOVAM *= SIC_INSTR
AND POSBT.QUANTITY <> 0
AND POSBT.COD_PORT = POS.COD_PORT
AND POSBT.SICOVAM = POS.SICOVAM
AND POSBT.QUANTITY = POS.QUANTITY

DECLARE @DAT_PRO varchar(8)
SELECT @DAT_PRO = '20070806'

SELECT DISTINCT PROFIL_ID, POSBT.SICOVAM, POSBT.FAIRVALUE, PRIX.THEO,
POS.FAIRVALUE, POSBT.QUANTITY, POSBT.COD_PORT, POSBT.COD_DEVISE,
'20070806',
GETDATE()
FROM IMP_VAR_DETAIL_POS_BT_CORRIGE POSBT, REF_PORT_SOURCE_HISTORIQUE RPS,
IMP_SOPH_PRIX PRIX, IMP_VAR_DETAIL_POS_GEN_CORRIGE POS
WHERE RPS.DAT_PRO_UTIL = @DAT_PRO
AND POSBT.DAT_PRO = @DAT_PRO
AND PRIX.DAT_PRO = @DAT_PRO
AND POS.DAT_PRO = @DAT_PRO
AND SOURCE = 'SOPHIS'
AND POSBT.COD_PORT = RPS.COD_PORT
AND POSBT.SICOVAM *= SIC_INSTR
AND POSBT.QUANTITY <> 0
AND POSBT.COD_PORT = POS.COD_PORT
AND POSBT.SICOVAM = POS.SICOVAM
AND POSBT.QUANTITY = POS.QUANTITY

merci

Bonne journée

Brigitte


Fred BROUARD
Le #11852771
-- As tu essayé :

DECLARE @DAT_PRO DATETIME
SELECT @DAT_PRO = '20070806'

SELECT DISTINCT PROFIL_ID, POSBT.SICOVAM,
POSBT.FAIRVALUE, PRIX.THEO,
POS.FAIRVALUE, POSBT.QUANTITY, POSBT.COD_PORT,
POSBT.COD_DEVISE, @DAT_PRO, GETDATE()

FROM IMP_VAR_DETAIL_POS_BT_CORRIGE POSBT
INNER JOIN REF_PORT_SOURCE_HISTORIQUE RPS
ON POSBT.COD_PORT = RPS.COD_PORT
LEFT OUTER JOIN IMP_SOPH_PRIX PRIX
ON POSBT.SICOVAM = SIC_INSTR
INNER JOIN IMP_VAR_DETAIL_POS_GEN_CORRIGE POS
ON POSBT.COD_PORT = POS.COD_PORT
AND POSBT.SICOVAM = POS.SICOVAM
AND POSBT.QUANTITY = POS.QUANTITY

WHERE RPS.DAT_PRO_UTIL = @DAT_PRO
AND POSBT.DAT_PRO = @DAT_PRO
AND PRIX.DAT_PRO = @DAT_PRO
AND POS.DAT_PRO = @DAT_PRO
AND SOURCE = 'SOPHIS'
AND POSBT.QUANTITY <> 0

-- voire :

DECLARE @DAT_PRO DATETIME
SELECT @DAT_PRO = '20070806'

SELECT *
FROM
(
SELECT DISTINCT PROFIL_ID, POSBT.SICOVAM,
POSBT.FAIRVALUE, PRIX.THEO,
POS.FAIRVALUE, POSBT.QUANTITY, POSBT.COD_PORT,
POSBT.COD_DEVISE, @DAT_PRO, GETDATE()

FROM IMP_VAR_DETAIL_POS_BT_CORRIGE POSBT
INNER JOIN REF_PORT_SOURCE_HISTORIQUE RPS
ON POSBT.COD_PORT = RPS.COD_PORT
LEFT OUTER JOIN IMP_SOPH_PRIX PRIX
ON POSBT.SICOVAM = SIC_INSTR
INNER JOIN IMP_VAR_DETAIL_POS_GEN_CORRIGE POS
ON POSBT.COD_PORT = POS.COD_PORT
AND POSBT.SICOVAM = POS.SICOVAM
AND POSBT.QUANTITY = POS.QUANTITY

WHERE RPS.DAT_PRO_UTIL = @DAT_PRO
AND POSBT.DAT_PRO = @DAT_PRO
AND PRIX.DAT_PRO = @DAT_PRO
AND POS.DAT_PRO = @DAT_PRO
AND SOURCE = 'SOPHIS'
)
WHERE NOT POSBT.QUANTITY = 0 -- ou encore POSBT.QUANTITY <> 0



En outre, y a t-il des index sur :
Table colonnes
------------------------------- ----------------------
IMP_VAR_DETAIL_POS_BT_CORRIGE COD_PORT, SICOVAM, QUANTITY
IMP_VAR_DETAIL_POS_BT_CORRIGE DAT_PRO
IMP_VAR_DETAIL_POS_BT_CORRIGE SICOVAM

IMP_SOPH_PRIX DAT_PRO
IMP_SOPH_PRIX SIC_INSTR

IMP_VAR_DETAIL_POS_GEN_CORRIGE COD_PORT, SICOVAM, QUANTITY
IMP_VAR_DETAIL_POS_GEN_CORRIGE DAT_PRO

REF_PORT_SOURCE_HISTORIQUE DAT_PRO_UTIL
REF_PORT_SOURCE_HISTORIQUE COD_PORT


?

A +



Brigitte a écrit :
Bonjour,

Comment peut-on expliquer que ces deux requêtes ont un temps d'exécution
totalement différent :

SELECT DISTINCT PROFIL_ID, POSBT.SICOVAM, POSBT.FAIRVALUE, PRIX.THEO,
POS.FAIRVALUE, POSBT.QUANTITY, POSBT.COD_PORT, POSBT.COD_DEVISE, '20070806',
GETDATE()
FROM IMP_VAR_DETAIL_POS_BT_CORRIGE POSBT, REF_PORT_SOURCE_HISTORIQUE RPS,
IMP_SOPH_PRIX PRIX, IMP_VAR_DETAIL_POS_GEN_CORRIGE POS
WHERE RPS.DAT_PRO_UTIL = '20070806'
AND POSBT.DAT_PRO = '20070806'
AND PRIX.DAT_PRO = '20070806'
AND POS.DAT_PRO = '20070806'
AND SOURCE = 'SOPHIS'
AND POSBT.COD_PORT = RPS.COD_PORT
AND POSBT.SICOVAM *= SIC_INSTR
AND POSBT.QUANTITY <> 0
AND POSBT.COD_PORT = POS.COD_PORT
AND POSBT.SICOVAM = POS.SICOVAM
AND POSBT.QUANTITY = POS.QUANTITY

DECLARE @DAT_PRO varchar(8)
SELECT @DAT_PRO = '20070806'

SELECT DISTINCT PROFIL_ID, POSBT.SICOVAM, POSBT.FAIRVALUE, PRIX.THEO,
POS.FAIRVALUE, POSBT.QUANTITY, POSBT.COD_PORT, POSBT.COD_DEVISE, '20070806',
GETDATE()
FROM IMP_VAR_DETAIL_POS_BT_CORRIGE POSBT, REF_PORT_SOURCE_HISTORIQUE RPS,
IMP_SOPH_PRIX PRIX, IMP_VAR_DETAIL_POS_GEN_CORRIGE POS
WHERE RPS.DAT_PRO_UTIL = @DAT_PRO
AND POSBT.DAT_PRO = @DAT_PRO
AND PRIX.DAT_PRO = @DAT_PRO
AND POS.DAT_PRO = @DAT_PRO
AND SOURCE = 'SOPHIS'
AND POSBT.COD_PORT = RPS.COD_PORT
AND POSBT.SICOVAM *= SIC_INSTR
AND POSBT.QUANTITY <> 0
AND POSBT.COD_PORT = POS.COD_PORT
AND POSBT.SICOVAM = POS.SICOVAM
AND POSBT.QUANTITY = POS.QUANTITY

merci

Bonne journée

Brigitte




--
Frédéric BROUARD, MVP SQL Server, expert bases de données et langage SQL
Le site sur le langage SQL et les SGBDR : http://sqlpro.developpez.com
Audit, conseil, expertise, formation, modélisation, tuning, optimisation
********************* http://www.datasapiens.com ***********************
Brigitte
Le #11852741
Merci, le temps d'exécution est passé de 25mn à 14s.
Voici les index,

Table colonnes
------------------------------- ----------------------
IMP_VAR_DETAIL_POS_BT_CORRIGE ID_VAR_DETAIL_POS_BT_CORRIGE clustered
IMP_VAR_DETAIL_POS_BT_CORRIGE DAT_PRO, SICOVAM
IMP_VAR_DETAIL_POS_BT_CORRIGE SICOVAM

IMP_SOPH_PRIX DAT_PRO

IMP_VAR_DETAIL_POS_GEN_CORRIGE ID_VAR_DETAIL_POS_GEN_CORRIGE clustered
IMP_VAR_DETAIL_POS_GEN_CORRIGE DAT_PRO, SICOVAM

REF_PORT_SOURCE_HISTORIQUE DAT_PRO_UTIL, COD_PORT, SOURCE
REF_PORT_SOURCE_HISTORIQUE COD_PORT



Bonne journée et bon week-end

Merci

Brigitte
"Fred BROUARD" a écrit :

-- As tu essayé :

DECLARE @DAT_PRO DATETIME
SELECT @DAT_PRO = '20070806'

SELECT DISTINCT PROFIL_ID, POSBT.SICOVAM,
POSBT.FAIRVALUE, PRIX.THEO,
POS.FAIRVALUE, POSBT.QUANTITY, POSBT.COD_PORT,
POSBT.COD_DEVISE, @DAT_PRO, GETDATE()

FROM IMP_VAR_DETAIL_POS_BT_CORRIGE POSBT
INNER JOIN REF_PORT_SOURCE_HISTORIQUE RPS
ON POSBT.COD_PORT = RPS.COD_PORT
LEFT OUTER JOIN IMP_SOPH_PRIX PRIX
ON POSBT.SICOVAM = SIC_INSTR
INNER JOIN IMP_VAR_DETAIL_POS_GEN_CORRIGE POS
ON POSBT.COD_PORT = POS.COD_PORT
AND POSBT.SICOVAM = POS.SICOVAM
AND POSBT.QUANTITY = POS.QUANTITY

WHERE RPS.DAT_PRO_UTIL = @DAT_PRO
AND POSBT.DAT_PRO = @DAT_PRO
AND PRIX.DAT_PRO = @DAT_PRO
AND POS.DAT_PRO = @DAT_PRO
AND SOURCE = 'SOPHIS'
AND POSBT.QUANTITY <> 0

-- voire :

DECLARE @DAT_PRO DATETIME
SELECT @DAT_PRO = '20070806'

SELECT *
FROM
(
SELECT DISTINCT PROFIL_ID, POSBT.SICOVAM,
POSBT.FAIRVALUE, PRIX.THEO,
POS.FAIRVALUE, POSBT.QUANTITY, POSBT.COD_PORT,
POSBT.COD_DEVISE, @DAT_PRO, GETDATE()

FROM IMP_VAR_DETAIL_POS_BT_CORRIGE POSBT
INNER JOIN REF_PORT_SOURCE_HISTORIQUE RPS
ON POSBT.COD_PORT = RPS.COD_PORT
LEFT OUTER JOIN IMP_SOPH_PRIX PRIX
ON POSBT.SICOVAM = SIC_INSTR
INNER JOIN IMP_VAR_DETAIL_POS_GEN_CORRIGE POS
ON POSBT.COD_PORT = POS.COD_PORT
AND POSBT.SICOVAM = POS.SICOVAM
AND POSBT.QUANTITY = POS.QUANTITY

WHERE RPS.DAT_PRO_UTIL = @DAT_PRO
AND POSBT.DAT_PRO = @DAT_PRO
AND PRIX.DAT_PRO = @DAT_PRO
AND POS.DAT_PRO = @DAT_PRO
AND SOURCE = 'SOPHIS'
)
WHERE NOT POSBT.QUANTITY = 0 -- ou encore POSBT.QUANTITY <> 0



En outre, y a t-il des index sur :
Table colonnes
------------------------------- ----------------------
IMP_VAR_DETAIL_POS_BT_CORRIGE COD_PORT, SICOVAM, QUANTITY
IMP_VAR_DETAIL_POS_BT_CORRIGE DAT_PRO
IMP_VAR_DETAIL_POS_BT_CORRIGE SICOVAM

IMP_SOPH_PRIX DAT_PRO
IMP_SOPH_PRIX SIC_INSTR

IMP_VAR_DETAIL_POS_GEN_CORRIGE COD_PORT, SICOVAM, QUANTITY
IMP_VAR_DETAIL_POS_GEN_CORRIGE DAT_PRO

REF_PORT_SOURCE_HISTORIQUE DAT_PRO_UTIL
REF_PORT_SOURCE_HISTORIQUE COD_PORT


?

A +



Brigitte a écrit :
> Bonjour,
>
> Comment peut-on expliquer que ces deux requêtes ont un temps d'exécution
> totalement différent :
>
> SELECT DISTINCT PROFIL_ID, POSBT.SICOVAM, POSBT.FAIRVALUE, PRIX.THEO,
> POS.FAIRVALUE, POSBT.QUANTITY, POSBT.COD_PORT, POSBT.COD_DEVISE, '20070806',
> GETDATE()
> FROM IMP_VAR_DETAIL_POS_BT_CORRIGE POSBT, REF_PORT_SOURCE_HISTORIQUE RPS,
> IMP_SOPH_PRIX PRIX, IMP_VAR_DETAIL_POS_GEN_CORRIGE POS
> WHERE RPS.DAT_PRO_UTIL = '20070806'
> AND POSBT.DAT_PRO = '20070806'
> AND PRIX.DAT_PRO = '20070806'
> AND POS.DAT_PRO = '20070806'
> AND SOURCE = 'SOPHIS'
> AND POSBT.COD_PORT = RPS.COD_PORT
> AND POSBT.SICOVAM *= SIC_INSTR
> AND POSBT.QUANTITY <> 0
> AND POSBT.COD_PORT = POS.COD_PORT
> AND POSBT.SICOVAM = POS.SICOVAM
> AND POSBT.QUANTITY = POS.QUANTITY
>
> DECLARE @DAT_PRO varchar(8)
> SELECT @DAT_PRO = '20070806'
>
> SELECT DISTINCT PROFIL_ID, POSBT.SICOVAM, POSBT.FAIRVALUE, PRIX.THEO,
> POS.FAIRVALUE, POSBT.QUANTITY, POSBT.COD_PORT, POSBT.COD_DEVISE, '20070806',
> GETDATE()
> FROM IMP_VAR_DETAIL_POS_BT_CORRIGE POSBT, REF_PORT_SOURCE_HISTORIQUE RPS,
> IMP_SOPH_PRIX PRIX, IMP_VAR_DETAIL_POS_GEN_CORRIGE POS
> WHERE RPS.DAT_PRO_UTIL = @DAT_PRO
> AND POSBT.DAT_PRO = @DAT_PRO
> AND PRIX.DAT_PRO = @DAT_PRO
> AND POS.DAT_PRO = @DAT_PRO
> AND SOURCE = 'SOPHIS'
> AND POSBT.COD_PORT = RPS.COD_PORT
> AND POSBT.SICOVAM *= SIC_INSTR
> AND POSBT.QUANTITY <> 0
> AND POSBT.COD_PORT = POS.COD_PORT
> AND POSBT.SICOVAM = POS.SICOVAM
> AND POSBT.QUANTITY = POS.QUANTITY
>
> merci
>
> Bonne journée
>
> Brigitte


--
Frédéric BROUARD, MVP SQL Server, expert bases de données et langage SQL
Le site sur le langage SQL et les SGBDR : http://sqlpro.developpez.com
Audit, conseil, expertise, formation, modélisation, tuning, optimisation
********************* http://www.datasapiens.com ***********************



Publicité
Poster une réponse
Anonyme