Solved

SQL performnace...

Posted on 2013-01-10
13
311 Views
Last Modified: 2013-04-04
The SQL is taking long time for me. Please help me in this.

SELECT   Distinct CAT.CATENTRY_ID,
         CAT.PARTNUMBER
FROM     CATENTRY CAT
         JOIN IMCCRP.IMC_ABC_PARTNO ABC ON CAT.CATENTRY_ID = ABC.CATENTRY_ID
         JOIN IMCCRP.IMC_APPLICATION AN ON AN.APPLICATION_NUMBER = ABC.ABC_NO
         JOIN IMCCRP.IMC_VEHICLE_MQT IVM ON IVM.BASEVEHICLEID = AN.BASE_VEHICLE_ID
WHERE    IVM.MAKENAME = 'Honda'

Thanks for your time..

Thanks
Krishna
0
Comment
Question by:vvsrk76
  • 4
  • 4
  • 3
  • +2
13 Comments
 
LVL 21

Expert Comment

by:mcsween
ID: 38763793
What database engine is this, MSSQL or DB2?

You need to add an index to the IVM.MAKENAME column
0
 

Author Comment

by:vvsrk76
ID: 38763818
DB2 database.

Is Query looks ok?
0
 
LVL 18

Expert Comment

by:daveslash
ID: 38763823
Since your select looks valid, let's make sure you have the appropriate indexes (and primary keys) in place.

CATENTRY.CATENTRY_ID
IMC_ABC_PARTNO.CATENTRY_ID
IMC_ABC_PARTNO.ABC_NO
IMCCRP.IMC_APPLICATION.APPLICATION_NUMBER
IMCCRP.IMC_APPLICATION.BASE_VEHICLE_ID
IMC_VEHICLE_MQT.MAKENAME, IMC_VEHICLE_MQT.BASEVEHICLEID

Of course, you'd find A LOT of useful information on performance by doing a Visual Explain on the query.

Create those indexes (or ensure they already exist), do a Visual Explain, and report back to us how it works for you.

HTH,
DaveSlash


Regards,
DaveSlash
0
Master Your Team's Linux and Cloud Stack!

The average business loses $13.5M per year to ineffective training (per 1,000 employees). Keep ahead of the competition and combine in-person quality with online cost and flexibility by training with Linux Academy.

 
LVL 18

Expert Comment

by:daveslash
ID: 38763829
Also, how many rows are in each table, and how long does the query actually take to run?
0
 

Author Comment

by:vvsrk76
ID: 38763964
Thank you so much for time..

I have  indexes on all tables..
IMC_APPLICATION table has 2 million records

IMC_ABC_PARTNO : 70K records

Catentry : 122K records

IMC_VEHICLE_MQT :14295 records

SQL execution time: 2 seconds.

I want to be reduce the sql execution time.We have so many calls for this query.I do not want to lock the tables for 2 sceonds. It is locking the other transactions..
0
 
LVL 18

Expert Comment

by:daveslash
ID: 38764082
When you say "I have  indexes on all tables", does that mean you have all the indexes I suggested?

Also, what did you find out when you did Visual Explain?
0
 
LVL 25

Expert Comment

by:Tomas Helgi Johannsson
ID: 38766544
Hi!

I would try these indexes if you don't have them.

On table IMC_ABC_PARTNO  the index (CATENTRY_ID, ABC_NO)
On table IMC_APPLICATION the index (APPLICATION_NUMBER, BASE_VEHICLE_ID)
On table IMC_VEHICLE_MQT the index (MAKENAME, BASEVEHICLEID)

Having index on only one column is often not enough for complex queries.
Hope this helps.

Regards,
     Tomas Helgi
0
 
LVL 18

Expert Comment

by:daveslash
ID: 38807719
Hi vvsrk76,

It's been several days since we heard from you. Did you get your query to perform acceptably? If so, how?

-- DaveSlash
0
 

Author Comment

by:vvsrk76
ID: 38808016
We are using the MQT's in DB2..

We are trying recreate the MQT.
0
 
LVL 48

Accepted Solution

by:
PortletPaul earned 500 total points
ID: 38842637
#1: AVOID using "distinct" (if you can)
#2: try reversing the table relationships (small to large)

SELECT /* and avoid distinct if you can */
      CAT.CATENTRY_ID
    , CAT.PARTNUMBER
/* try upending the table relationships */
from IMCCRP.IMC_VEHICLE_MQT IVM
     JOIN IMCCRP.IMC_APPLICATION AN ON IVM.BASEVEHICLEID     = AN.BASE_VEHICLE_ID
     JOIN IMCCRP.IMC_ABC_PARTNO ABC ON AN.APPLICATION_NUMBER = ABC.ABC_NO 
     join CATENTRY CAT              ON ABC.CATENTRY_ID       = CAT.CATENTRY_ID
WHERE IVM.MAKENAME = 'Honda'

Open in new window

0
 
LVL 48

Expert Comment

by:PortletPaul
ID: 38866954
Hi, is this solved?
0
 
LVL 48

Expert Comment

by:PortletPaul
ID: 38920691
Will you please decide if your question is answered.
0
 

Author Closing Comment

by:vvsrk76
ID: 39049473
Thank You
0

Featured Post

Resolve Critical IT Incidents Fast

If your data, services or processes become compromised, your organization can suffer damage in just minutes and how fast you communicate during a major IT incident is everything. Learn how to immediately identify incidents & best practices to resolve them quickly and effectively.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Occasionally there is a need to clean table columns, especially if you have inherited legacy data. There are obviously many ways to accomplish that, including elaborate UPDATE queries with anywhere from one to numerous REPLACE functions (even within…
This article describes how to use the timestamp of existing data in a database to allow Tableau to calculate the prior work day instead of relying on case statements or if statements to calculate the days of the week.
A short tutorial showing how to set up an email signature in Outlook on the Web (previously known as OWA). For free email signatures designs, visit https://www.mail-signatures.com/articles/signature-templates/?sts=6651 If you want to manage em…
In a recent question (https://www.experts-exchange.com/questions/29004105/Run-AutoHotkey-script-directly-from-Notepad.html) here at Experts Exchange, a member asked how to run an AutoHotkey script (.AHK) directly from Notepad++ (aka NPP). This video…

840 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question