MySql Table Optimizing

Posted on 2011-03-24
Last Modified: 2012-08-14
Hi, I have a table that has nearly 3 million rows in it.
Its on a MySql db.
When i query from it simply SELECT  * FROM TABLE
it takes about 4-5 mins for it to return the results for me.

I am using this table within another larger query, and the time to run the query has exceeded 12 hours! which i think is far to much.

I believe its to do with this table.

I have tried to Optimize the table by de fragmenting it.
i have also tried creating another table from it (which i suppose is similar to the above)
but it still takes a long time to query it.

Can anyone suggest what i can do to help speed up performance on this table?
Question by:Putoch
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 4
  • 3
  • 2
  • +1
LVL 23

Accepted Solution

OP_Zaharin earned 167 total points
ID: 35205599
- there is so much thing can be suggested but this article covers almost of everything you need. hope this article helps:

LVL 23

Expert Comment

ID: 35205626
more suggestion:
- try to use EXPLAIN query execution plan with your sql tool. this is to check whether your query uses INDEXES or not:

SELECT fieldname, fieldname
FROM tablename
WHERE fieldname = xxx
ORDER BY fieldname

- the '\G' will format the output result into a readable format.
- optimize your SQL based on the EXPLAIN result
LVL 75

Assisted Solution

by:Anthony Perkins
Anthony Perkins earned 166 total points
ID: 35206298
>>Zones: MySQL Server, MS SQL Server<<
This has nothing to do with SQL Server.  Please request the MS SQL Server zone be removed.
Simplifying Server Workload Migrations

This use case outlines the migration challenges that organizations face and how the Acronis AnyData Engine supports physical-to-physical (P2P), physical-to-virtual (P2V), virtual to physical (V2P), and cross-virtual (V2V) migration scenarios to address these challenges.


Author Comment

ID: 35206974
The reason i requested both zones is because i believed the theory behind any optimization of a table would be equal in either Mysql or MSSQL, the command lines may not be exactly the same , but the logic would.  And having both zones included meant i would have a better response in-case no one responded on either zone.

Please let me know if you have an issue with this acperkins

Author Comment

ID: 35206985
Hi OP_Zaharin,
thanks for those links.

I have checked what i could on the table format.
I defragmented the table and then decided that instead of running the whole script (which is made up of 3 queries)
That i would Create 3 tables to hold each of the queries, and see how that works.

I'll let you know the progress.
thank you for the advice

Author Comment

ID: 35207210
Hi All, i'm hoping someone can advice me on the EXPLAIN out put, i'm trying to read this to see what it means. If anyone could clarify it would be very much appreciated.


Assisted Solution

wolfgang_93 earned 167 total points
ID: 35210591
Are you actually trying to fetch all 3 million+ records from the table,
or do you have a clause limiting the number?

Some factors that can cause a fetch of 3 million+ records to take
a few minutes:
-  Fetching over a network (e.g. executing the command on a
   client which is fetching that number of records from a database
-  If the table involved is a MyISAM table, there is a lot of disk
   i/o. If the table were InnoDB instead, then most pages could be
   fetched from RAM where RAM is 1000 times faster than disk.

Try fetching a smaller number of records, say 100 records, like this:
   select * from table limit 100 offset 0

Also you mentioned that this is part of a larger query?

What do you mean by that? If you are doing a join, I can see if taking
hours to run if it involves a huge table and you do not have any
indexes on the fields involved in the join.
LVL 23

Expert Comment

ID: 35212633
Hi Putoch,
- a quick explanation on the explain plan column:

from the explain plan, the column that you might want to look into is the "type, possible_keys, key and rows"
- "type" column is the join/method use to match records from many tables. it will tell you whether it does a full table scan or not.
- "possible_keys" column indicates which indexes MySQL can choose from use to find the rows
- "key" column indicates the index that MySQL actually use. if its NULL meaning its not using any Index
- "rows" column display the number of records fetch when running each of the query step and this can tell you does your query step fetch correctly the amount of records as it should or not

- in all, EXPLAIN helps you to identify if your query is using the right approach in querying the tables involves and whether is uses the right Index or a full tablescan which usually the reason why a sql query go slow...

Author Closing Comment

ID: 35392178
Thanks Guys for your help on this. I was able to understand the Explain plan in Mysql, and got some good pointers on how to optimize the db and the queries i was running, unfortunately the query was still running for hours when i tried to make some changes. thanks for all your help. Putoch

Expert Comment

ID: 35394549
Sorry to hear that you still have an issue.

Going back to your original posting, I see you stated "I am using this table within another larger query".

I can't help wondering if you are talking about a JOIN for which we could have given you
more explicit help if we had an opportunity to see an example of the full query.

A big query involving a join that runs for hours can be made to run in seconds simply by making
sure that the fields involved in the join are indexed. Fields involved in sorting, grouping, and in
major selection should also be indexed for better performance.

Featured Post

Visualize your virtual and backup environments

Create well-organized and polished visualizations of your virtual and backup environments when planning VMware vSphere, Microsoft Hyper-V or Veeam deployments. It helps you to gain better visibility and valuable business insights.

Question has a verified solution.

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

JSON is being used more and more, besides XML, and you surely wanted to parse the data out into SQL instead of doing it in some Javascript. The below function in SQL Server can do the job for you, returning a quick table with the parsed data.
In this article we will learn how to fix  “Cannot install SQL Server 2014 Service Pack 2: Unable to install windows installer msi file” error ?
Viewers will learn how to use the INSERT statement to insert data into their tables. It will also introduce the NULL statement, to show them what happens when no value is giving for any given column.
Viewers will learn how to use the SELECT statement in SQL and will be exposed to the many uses the SELECT statement has.

756 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