Solved

SQL slow on DBase Table

Posted on 2000-02-14
9
369 Views
Last Modified: 2013-11-24
I am running a SQL query on a DBase table with about 12 000 entries.  It is extremely slow.  The Query is as follows :
   SELECT * FROM TABLENAME ORDER BY VDate, TLN

I know it is the order by clause that is slowing the query down but I must have it in.

I have one expression index on my Table:
   VDate+TLN

VDate is a Date field And TLN is a number field(10, 0)

Can anybody please help me speed up this query?
0
Comment
Question by:Leon_b
9 Comments
 
LVL 12

Expert Comment

by:rwilson032697
ID: 2518091
I think you need to create separate indexes as the query may not use the expression index.

Cheers,

Raymond.
0
 
LVL 15

Expert Comment

by:simonet
ID: 2518230
Creating adequate indexes is an option... a very good one.

However, I must warn you that on file-based tables (like dBase, Paradox, etc), SQL is not necessarily faster than the TTable object. Neither dBase nor Paradox benefit from using SQL.

SQL is an advantage on database-based tables (like Access, MSSQL, Oracle, Iterbase, etc).

Alex
0
 

Expert Comment

by:Michael_Benjamin_Perez
ID: 2518577
Can't you be more specific than '*', I know it seriously increases speed if you literally specify the columns you need...

G'Luck !
0
Salesforce Made Easy to Use

On-screen guidance at the moment of need enables you & your employees to focus on the core, you can now boost your adoption rates swiftly and simply with one easy tool.

 
LVL 17

Expert Comment

by:geobul
ID: 2519380
 If you can perform all actions with the set in one loop from top to bottom, you can set UniDirectional property to true. Set it before preparing or executing the query.
  This will speed up your query but you lose backward functionality.
  I presume that you are using this query for printing some kind of report and you can modify your code to work unidirectional through the SQL set.

Regards, Geo
0
 

Author Comment

by:Leon_b
ID: 2521747
Thanks for all the suggestions, but nothing really speeds up the query enough.  I have a new question though regarding the same subject.

I took the ORDER BY out of the statement and ran it from SQL Explorer.  So in affect I ran a simple
SELECT * FROM TABLENAME query. In SQL explorer this query runs a lot faster than in my application even though the queries are exactly the same.

Why is this?
0
 
LVL 12

Expert Comment

by:rwilson032697
ID: 2521774
Did it have indexes on the fields in the order by clause?
0
 

Author Comment

by:Leon_b
ID: 2521853
Yes
0
 
LVL 1

Accepted Solution

by:
RLancaster earned 100 total points
ID: 2522073
specify the column names for a dramatic speed increase

another point to note is that TypedBinary fields seem to slow down queries dramatically ... try excluding these field types from your queries

this should help :)
0
 

Author Comment

by:Leon_b
ID: 2522084
It was the typed binary fields.  Removing these fields from the query Made a dramatic speed increase.  Thanx to everyone else trying to help.
0

Featured Post

Free Tool: Site Down Detector

Helpful to verify reports of your own downtime, or to double check a downed website you are trying to access.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

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

Hello everybody This Article will show you how to validate number with TEdit control, What's the TEdit control? TEdit is a standard Windows edit control on a form, it allows to user to write, read and copy/paste single line of text. Usua…
Many companies are making the switch from Microsoft to Google Apps (https://www.google.com/work/apps/business/). Use this article to learn more about what Google Apps has to offer and to help if you’re planning on migrating to Google Apps. It is …
The viewer will learn how to use the =DISCRINV command to create a discrete random variable, use this command to model a set of probabilities and outcomes in a Monte Carlo simulation, and learn how to find the standard deviation of a set of probabil…
The viewer will learn how to use a discrete random variable to simulate the return on an investment over a period of years, create a Monte Carlo simulation using the discrete random variable, and create a graph to represent the possible returns over…

830 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