473,396 Members | 2,106 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 473,396 software developers and data experts.

SQL help

SKC
Hi all,
Is there a better way of writting this SQL :

SELECT DECIMAL(ROUND(AVG(COALESCE(REPT_EXEC_TIME_NBR,0.0)
),1),19,1)FROM TABLE1
WHERE REPORT_ID = temp_ID AND RESOURCE_ID = planResID AND
IFSC_USER_ID IN (SELECT IFSC_USER_ID FROM TABLE2 WHERE BUS_CAT_CD =
lob AND INTERNAL_USER_IND IN ( internalAmex, internalNonAmex )) AND
MONTH (REPT_REQ_DT) = temp_monthID AND YEAR (REPT_REQ_DT) = reportYear
AND DELIV_STATUS_CD IN (reportReady);

This SQL is taken out from a Stored proc.

Thanks in advance...
Nov 12 '05 #1
6 3036
AK
> MONTH (REPT_REQ_DT) = temp_monthID AND YEAR (REPT_REQ_DT) = reportYear

REPT_REQ_DT BETWEEN DATE1 AND DATE2 might perform better
Nov 12 '05 #2
cs****@gmail.com (SKC) wrote in message news:<de**************************@posting.google. com>...
Hi all,
Is there a better way of writting this SQL :

SELECT DECIMAL(ROUND(AVG(COALESCE(REPT_EXEC_TIME_NBR,0.0)
),1),19,1)FROM TABLE1
WHERE REPORT_ID = temp_ID AND RESOURCE_ID = planResID AND
IFSC_USER_ID IN (SELECT IFSC_USER_ID FROM TABLE2 WHERE BUS_CAT_CD =
lob AND INTERNAL_USER_IND IN ( internalAmex, internalNonAmex )) AND
MONTH (REPT_REQ_DT) = temp_monthID AND YEAR (REPT_REQ_DT) = reportYear
AND DELIV_STATUS_CD IN (reportReady);

This may be another way. But, I don't know better or not.
SELECT DECIMAL(ROUND(AVG(COALESCE(REPT_EXEC_TIME_NBR,0.0) ),1),19,1)
FROM TABLE1 T1
WHERE REPORT_ID = temp_ID
AND RESOURCE_ID = planResID
AND EXISTS
(SELECT *
FROM TABLE2 T2
WHERE T2.IFSC_USER_ID = T1.IFSC_USER_ID
AND BUS_CAT_CD = lob
AND INTERNAL_USER_IND
IN ( internalAmex, internalNonAmex )
)
AND MONTH (REPT_REQ_DT) = temp_monthID
AND YEAR (REPT_REQ_DT) = reportYear
AND DELIV_STATUS_CD IN (reportReady)
;
Nov 12 '05 #3
SKC wrote:
Hi all,
Is there a better way of writting this SQL :

SELECT DECIMAL(ROUND(AVG(COALESCE(REPT_EXEC_TIME_NBR,0.0)
),1),19,1)FROM TABLE1
WHERE REPORT_ID = temp_ID AND RESOURCE_ID = planResID AND
IFSC_USER_ID IN (SELECT IFSC_USER_ID FROM TABLE2 WHERE BUS_CAT_CD =
lob AND INTERNAL_USER_IND IN ( internalAmex, internalNonAmex )) AND
MONTH (REPT_REQ_DT) = temp_monthID AND YEAR (REPT_REQ_DT) = reportYear
AND DELIV_STATUS_CD IN (reportReady);


You could try if a correlated subquery is any better:

SELECT DECIMAL(ROUND(AVG(COALESCE(REPT_EXEC_TIME_NBR,0.0) ),1),19,1)
FROM TABLE1
WHERE REPORT_ID = temp_ID AND
RESOURCE_ID = planResID AND
EXISTS ( SELECT IFSC_USER_ID
FROM TABLE2
WHERE BUS_CAT_CD = lob AND
INTERNAL_USER_IND IN
( internalAmex, internalNonAmex ) AND
table2.IFSC_USER_ID = table1.IFSC_USER_ID ) AND
MONTH(REPT_REQ_DT) = temp_monthID AND
YEAR(REPT_REQ_DT) = reportYear AND
DELIV_STATUS_CD = reportReady;

--
Knut Stolze
Information Integration
IBM Germany / University of Jena
Nov 12 '05 #4
AK
Knut,

should there ever be an index on REPT_REQ_DT, this predicate would
never utilise that index:

MONTH(REPT_REQ_DT) = temp_monthID AND
YEAR(REPT_REQ_DT) = reportYear AND

so it could run way slower than this one

REPT_REQ_DT BETWEEN ... AND ...

What do you think?
Nov 12 '05 #5
AK wrote:
Knut,

should there ever be an index on REPT_REQ_DT, this predicate would
never utilise that index:

MONTH(REPT_REQ_DT) = temp_monthID AND
YEAR(REPT_REQ_DT) = reportYear AND

so it could run way slower than this one

REPT_REQ_DT BETWEEN ... AND ...

What do you think?


Yes, the BETWEEN has a good chance of being more efficient.

Besides that, there is another alternative: You could use 2 generated
columns, one with MONTH(rept_req_dt) and another with YEAR(rept_req_dt).
Then create indexes on those two columns.

It might be worthwhile to see what the BETWEEN (along with the index)
changes, and then evaluate the difference that might or might not come with
the rephrased query. I wouldn't change both together, though.

--
Knut Stolze
Information Integration
IBM Germany / University of Jena
Nov 12 '05 #6
AK
>
Besides that, there is another alternative: You could use 2 generated
columns, one with MONTH(rept_req_dt) and another with YEAR(rept_req_dt).
Then create indexes on those two columns.


in my experience the optimizer is a little bit reluctant to choose
index OR-ing plans. A single index on both generated columns might do
way better
Nov 12 '05 #7

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

21
by: Dave | last post by:
After following Microsofts admonition to reformat my system before doing a final compilation of my app I got many warnings/errors upon compiling an rtf file created in word. I used the Help...
9
by: Tom | last post by:
A question for gui application programmers. . . I 've got some GUI programs, written in Python/wxPython, and I've got a help button and a help menu item. Also, I've got a compiled file made with...
6
by: wukexin | last post by:
Help me, good men. I find mang books that introduce bit "mang header files",they talk too bit,in fact it is my too fool, I don't learn it, I have do a test program, but I have no correct doing...
3
by: Colin J. Williams | last post by:
Python advertises some basic service: C:\Python24>python Python 2.4.1 (#65, Mar 30 2005, 09:13:57) on win32 Type "help", "copyright", "credits" or "license" for more information. >>> With...
7
by: Corepaul | last post by:
Missing Help Files When I enter "recordset" as the keyword and search the Visual Basic Help index, I get many topics of interest in the resulting list. But there isn't any information available...
5
by: Steve | last post by:
I have written a help file (chm) for a DLL and referenced it using Help.ShowHelp My expectation is that a developer using my DLL would be able to access this help file during his development time...
8
by: Mark | last post by:
I have loaded Visual Studio .net on my home computer and my laptop, but my home computer has an abbreviated help screen not 2% of the help on my laptop. All the settings look the same on both...
10
by: JonathanOrlev | last post by:
Hello everybody, I wrote this comment in another message of mine, but decided to post it again as a standalone message. I think that Microsoft's Office 2003 help system is horrible, probably...
1
by: trunxnirvana007 | last post by:
'UPGRADE_WARNING: Array has a new behavior. Click for more: 'ms-help://MS.VSCC.v80/dv_commoner/local/redirect.htm?keyword="9B7D5ADD-D8FE-4819-A36C-6DEDAF088CC7"' 'UPGRADE_WARNING: Couldn't resolve...
0
by: hitencontractor | last post by:
I am working on .NET Version 2003 making an SDI application that calls MS Excel 2003. I added a menu item called "MyApp Help" in the end of the menu bar to show Help-> About. The application...
0
by: Charles Arthur | last post by:
How do i turn on java script on a villaon, callus and itel keypad mobile phone
0
by: ryjfgjl | last post by:
In our work, we often receive Excel tables with data in the same format. If we want to analyze these data, it can be difficult to analyze them because the data is spread across multiple Excel files...
0
BarryA
by: BarryA | last post by:
What are the essential steps and strategies outlined in the Data Structures and Algorithms (DSA) roadmap for aspiring data scientists? How can individuals effectively utilize this roadmap to progress...
1
by: nemocccc | last post by:
hello, everyone, I want to develop a software for my android phone for daily needs, any suggestions?
1
by: Sonnysonu | last post by:
This is the data of csv file 1 2 3 1 2 3 1 2 3 1 2 3 2 3 2 3 3 the lengths should be different i have to store the data by column-wise with in the specific length. suppose the i have to...
0
by: Hystou | last post by:
There are some requirements for setting up RAID: 1. The motherboard and BIOS support RAID configuration. 2. The motherboard has 2 or more available SATA protocol SSD/HDD slots (including MSATA, M.2...
0
marktang
by: marktang | last post by:
ONU (Optical Network Unit) is one of the key components for providing high-speed Internet services. Its primary function is to act as an endpoint device located at the user's premises. However,...
0
by: Hystou | last post by:
Most computers default to English, but sometimes we require a different language, especially when relocating. Forgot to request a specific language before your computer shipped? No problem! You can...
0
Oralloy
by: Oralloy | last post by:
Hello folks, I am unable to find appropriate documentation on the type promotion of bit-fields when using the generalised comparison operator "<=>". The problem is that using the GNU compilers,...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.