Solved

Large SQL Table Need Group and SubGroup

Posted on 2009-04-09
3
724 Views
Last Modified: 2012-08-14
Hello,
I have a table that has 2.5 million records in it and I want to be able to display this data in "groups" on one specific field.  
Assume the field is "Tag" and it is a VARCHAR(50).  
What I want to be able to do is list all the rows grouped by the first character of the TAG.  

However, because there are so many records, I also want to display this data in "pages".

For Example, for all rows that begin with "A", I want to then group by the 2nd character:
AAxxxx- AByyyyy
AC- AD
AD - AE
AF-  AG
Etc.
xxxxxx and yyyyy woudl be the remainder of the FIRST and LAST TAG name in the group.
The result would be a 26 groups under A for each letter of the alphabet.  When someone selects the AA-AB group, I would then load all the Tags that have LEFT(Tag,2) in ('AA','AB')

The table is stored in a MS SQL 2000 database.  Any suggestions would be greatly appreciated.

Thanks
0
Comment
Question by:aspireworks
  • 2
3 Comments
 
LVL 17

Expert Comment

by:k_murli_krishna
ID: 24113429
SELECT tag, <column-list> FROM YourTable WHERE ............. GROUP BY SUBSTRING(tag,1,2), SUBSTRING(tag,3,2), <column-list> ORDER BY .............;
0
 

Author Comment

by:aspireworks
ID: 24117946
Thanks, it seemed to get me going down the right path, but didn't quite give me the results I was looking for.
I was able to come up with this code, but it runs REALLY slow.
Here's my SQL:
SELECT DISTINCT code, 
   (SELECT TOP 1 tag FROM table WHERE  SUBSTRING(tag,1,2) = code and LEN(tag) > 2 ORDER BY tag ASC) -- return 1st TAG in group code
,(SELECT TOP1 tag FROM TABLE WHERE SUBSTRING(tag,1,2) = code and LEN(tag) > 2 ORDER BY tag desc) -- return LAST TAG in group code   
FROM TABLE bb (NOLOCK)
INNER JOIN  
(SELECT DISTINCT SUBSTRING(tag,1,2) AS code FROM TABLE WHERE LEN(tag) > 2) cc
ON SUBSTRING(tag,1,2) = cc.code 
ORDER BY code ASC

Open in new window

0
 
LVL 17

Accepted Solution

by:
k_murli_krishna earned 500 total points
ID: 24121522
Try a simpler version:
SELECT DISTINCT SUBSTRING(tag,1,2),
                             (SELECT TOP 1 tag FROM table WHERE  LEN(tag) > 2 ORDER BY tag ASC) ,
                             (SELECT TOP 1 tag FROM TABLE WHERE LEN(tag) > 2 ORDER BY tag DESC)
FROM TABLE bb
GROUP BY  SUBSTRING(tag,1,2);

You can remove the DISTINCT if it is not necessary.

 


   

0

Featured Post

NAS Cloud Backup Strategies

This article explains backup scenarios when using network storage. We review the so-called “3-2-1 strategy” and summarize the methods you can use to send NAS data to the cloud

Question has a verified solution.

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

Ever wondered why sometimes your SQL Server is slow or unresponsive with connections spiking up but by the time you go in, all is well? The following article will show you how to install and configure a SQL job that will send you email alerts includ…
This article shows gives you an overview on SQL Server 2016 row level security. You will also get to know the usages of row-level-security and how it works
Viewers will learn how to use the SELECT statement in SQL and will be exposed to the many uses the SELECT statement has.
Viewers will learn how to use the UPDATE and DELETE statements to change or remove existing data from their tables. Make a table: Update a specific column given a specific row using the UPDATE statement: Remove a set of values using the DELETE s…

776 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