Solved

Lowest Data Value within a sql row

Posted on 2014-07-21
2
180 Views
Last Modified: 2014-07-21
I have a table defined as

OfficeLocID int
DistanceHeadquarters int
DistanceOffice1 int
DistanceOffice2 int
DistanceOffice3 int
DistanceOffice4 int
DistanceOffice5 int

I need to write a query that for each row, will return which field has the lowest value and what field it is

(Note: No 2 distances would have same value)

For example if the data was

OfficeLocID DistanceHeadquarters DistanceOffice1 DistanceOffice2 DistancetOffice3 DistanceOffice4 DistanceOffice5
1                       23                                      30                            40                       50                              20                    32
2                       12                                      50                            40                       51                              20                    32

I would want results to be

OfficeLocID     ClosestLocation                             ClosestLocationDistance
1                        DistanceOffice4                                        20  
2                        DistanceHeadquarters                           12
0
Comment
Question by:johnnyg123
2 Comments
 
LVL 6

Accepted Solution

by:
ksrsrinivasan earned 500 total points
ID: 40209317
One possible solution is to unpivot and select the minimum distance and do a lookup

DECLARE @tbl TABLE
(
    OfficeLocID int,
    DistanceHeadquarters int,
    DistanceOffice1 int,
    DistanceOffice2 int,
    DistanceOffice3 int,
    DistanceOffice4 int,
    DistanceOffice5 int
)

INSERT INTO @tbl
(
    OfficeLocID,
    DistanceHeadquarters,
    DistanceOffice1,
    DistanceOffice2,
    DistanceOffice3,
    DistanceOffice4,
    DistanceOffice5
)
VALUES
(
    1,
    23,
    30,
    40,
    50,
    20,
    32
),
(
    2,
    12,
    50,
    40,
    51,
    20,
    32
)

SELECT ref.OfficeLocID, MIN(un.value) [ClosestLocationDistance],
CASE MIN(un.value)
    WHEN DistanceHeadquarters THEN N'DistanceHeadquarters'
    WHEN DistanceOffice1 THEN N'DistanceOffice1'
    WHEN DistanceOffice2 THEN N'DistanceOffice2'
    WHEN DistanceOffice3 THEN N'DistanceOffice3'
    WHEN DistanceOffice4 THEN N'DistanceOffice4'
    WHEN DistanceOffice5 THEN N'DistanceOffice5'
END AS [ClosestLocation]
FROM @tbl unpivot(value for DistanceDesc in (DistanceHeadquarters,
    DistanceOffice1,
    DistanceOffice2,
    DistanceOffice3,
    DistanceOffice4,
    DistanceOffice5)) un
INNER JOIN
    @tbl ref
ON
    ref.OfficeLocID = un.OfficeLocID
GROUP BY
    ref.OfficeLocID,
    ref.DistanceHeadquarters,
    ref.DistanceOffice1,
    ref.DistanceOffice2,
    ref.DistanceOffice3,
    ref.DistanceOffice4,
    ref.DistanceOffice5

Open in new window

0
 

Author Closing Comment

by:johnnyg123
ID: 40209484
Excellent!!
0

Featured Post

VMware Disaster Recovery and Data Protection

In this expert guide, you’ll learn about the components of a Modern Data Center. You will use cases for the value-added capabilities of Veeam®, including combining backup and replication for VMware disaster recovery and using replication for data center migration.

Question has a verified solution.

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

This is basically a blog post I wrote recently. I've found that SARGability is poorly understood, and since many people don't read blogs, I figured I'd post it here as an article. SARGable is an adjective in SQL that means that an item can be fou…
If you have heard of RFC822 date formats, they can be quite a challenge in SQL Server. RFC822 is an Internet standard format for email message headers, including all dates within those headers. The RFC822 protocols are available in detail at:   ht…
This Micro Tutorial demonstrates using Microsoft Excel pivot tables, how to reverse engineer competitors' marketing strategies through backlinks.
With Secure Portal Encryption, the recipient is sent a link to their email address directing them to the email laundry delivery page. From there, the recipient will be required to enter a user name and password to enter the page. Once the recipient …

772 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