Solved

Correct ordering

Posted on 2016-11-06
16
62 Views
Last Modified: 2016-12-07
Hi All

 Example: I have data in a field like this:
 adesc
 AA001162
 AAAAAAA
 AABBBBB
 AAZZZZZ
 AA12345
 B1.2
 B1.12
 C10
 C2
 D10
 D2
 I want it to be sorted as this:
 adesc
 AAAAAAA
 AABBBBB
 AAZZZZZ
 AA001162
 AA12345
 B1.12
 B1.2
 C10
 C2
 D10
 D2
0
Comment
Question by:DatabaseDek
[X]
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
  • 6
  • 5
  • 3
  • +1
16 Comments
 
LVL 50

Expert Comment

by:Gustav Brock
ID: 41876094
You can do that in a query with

Order By
    Left([DoorCode], 2),
    Val("9" & Mid([DoorCode], 3))

/gustav
0
 
LVL 30

Expert Comment

by:hnasr
ID: 41876116
Isn't this the correct required output?
adesc
AA001162
AA12345
AAAAAAA
AABBBBB
AAZZZZZ
B1.2
B1.12
C2
C10
D2
D10
0
 

Author Comment

by:DatabaseDek
ID: 41876134
I will try that Gustav

Hnasr
Actually that would more than suffice.
Ideally
 B1.2 should come after
 B1.12

But what you have is much better than what I get
0
The Eight Noble Truths of Backup and Recovery

How can IT departments tackle the challenges of a Big Data world? This white paper provides a roadmap to success and helps companies ensure that all their data is safe and secure, no matter if it resides on-premise with physical or virtual machines or in the cloud.

 
LVL 30

Expert Comment

by:hnasr
ID: 41876149
Input:
Table a (aid, adesc)
aID      adesc
01      AA001162
02      AAAAAAA
03      AABBBBB
04      AAZZZZZ
05      AA12345
06      B1.2
07      B1.12
08      C10
09      C2
10      D10
11      D2

Required Output:
aID      adesc
01      AA001162
05      AA12345
02      AAAAAAA
03      AABBBBB
04      AAZZZZZ
06      B1.2
07      B1.12
09      C2
08      C10
11      D2
10      D10

Process:
Adding a function in modules.
Convert each numeric piece to a 10 digit string by adding 0's to beginning of number.
Rejoin strings and sort.

Query:
SELECT a.aID, a.adesc
FROM a
ORDER BY finedAlphaNumeric([adesc]);

Open in new window

sort-alpha-numeric.accdb
0
 
LVL 50

Expert Comment

by:Gustav Brock
ID: 41876150
A solution is not possible if you neither can define nor decide how to sort.

/gustav
1
 
LVL 47

Accepted Solution

by:
Dale Fye (Access MVP) earned 250 total points
ID: 41876404
It would take longer to run, but you could create two functions, one to pull back the Alpha portion of the field and the second to pull back the Numeric portion.  Then you would sort by the returned value of these two functions.

Since your #'s all appear to be at the end, you could strip them out with:
Public Function StripTrailingNumbers(ByVal SomeVal as String) as String

    Do
        if isnumeric(Right(SomeVal, 1)) then
            SomeVal = Left(SomeVal, Len(SomeVal)-1)
        Else
             Exit Do
        End If
    Loop

    StripTrailingNumbers  = SomeVal

End Function

Open in new window

Then the second function would return a numeric so that the numbers sort properly:

Public Function TrailingNumbers(SomeVal as string) as Double

    Dim intLoop as integer
    
    For intLoop = 1 to Len(SomeVal)
        if isnumeric(Mid(SomeVal, intLoop)) Then
            TrailingNumbers = Val(Mid(SomeVal, intLoop))
            Exit Function
        endif
    Next

    TrailingNumbers = 0

End Function

Open in new window


Then, your query would look something like:

SELECT [yourField]
FROM yourTable
ORDER BY StripTrailingNumbers([yourField]), TrailingNumbers([yourField])
0
 

Author Comment

by:DatabaseDek
ID: 41877947
Gustav

You cannot decide what sorting system you need when you do not know and when your customer does not know what he is going to get from his customer. It is simply a case of getting the best guess. Or perhaps just something better than the standard access stuff.

Hnasr

I cannot open your file I am still on Access 2002. Can you convert it please.

Dale

I will give that a try. Rushing to finish something this week!!!
0
 
LVL 30

Assisted Solution

by:hnasr
hnasr earned 250 total points
ID: 41877963
Here it is in mdb format.
sort-alpha-numeric.mdb
0
 
LVL 50

Expert Comment

by:Gustav Brock
ID: 41878185
It is simply a case of getting the best guess.


Well, then my straight solution is the best, simple as it is. It fulfills your example data and sorting.

/gustav
0
 
LVL 30

Expert Comment

by:hnasr
ID: 41878584
My comment was based on this challenging requirement:

customer can enter door numbers with any alpha numeric combination, inc decimal points anywhere. So writing code or a function may be too much

https://www.experts-exchange.com/questions/28979884/Orderby-function.html#a41867276

Although it handles the simple ABC123 entry, I may assume entries like,
adesc
A1B2C3D
A01X
A2
2A
2A10
A10
Which sorts to:
adesc
2A
2A10
A1B2C3D
A01X
A2        
A10
0
 

Author Closing Comment

by:DatabaseDek
ID: 41895777
Brilliant Guys. Thank you
0
 

Author Comment

by:DatabaseDek
ID: 41895791
How do I sort using these functions as "Desc"
0
 
LVL 47

Expert Comment

by:Dale Fye (Access MVP)
ID: 41895890
ARe you talking to me?
 
ORDER BY StripTrailingNumbers([yourField]), TrailingNumbers([yourField]) DESC

or if you want the Alpa part descending as well

ORDER BY StripTrailingNumbers([yourField]) DESC, TrailingNumbers([yourField]) DESC
0
 
LVL 30

Expert Comment

by:hnasr
ID: 41896185
Descending order:
SELECT a.aID, a.adesc, findAlphaNumeric([adesc])
FROM a
ORDER BY findAlphaNumeric([adesc]) DESC;

Open in new window

Modified function to properly sort entries such as 01X, and 1A .
-sort-alpha-numeric-2.mdb
0
 

Author Comment

by:DatabaseDek
ID: 41916313
Brilliant. Thank you.

Derek
0
 
LVL 30

Expert Comment

by:hnasr
ID: 41916466
Welcome!
0

Featured Post

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.

Question has a verified solution.

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

Phishing attempts can come in all forms, shapes and sizes. No matter how familiar you think you are with them, always remember to take extra precaution when opening an email with attachments or links.
The Windows Phone Theme Colours is a tight, powerful, and well balanced palette. This tiny Access application makes it a snap to select and pick a value. And it doubles as an intro to implementing WithEvents, one of Access' hidden gems.
Familiarize people with the process of utilizing SQL Server views from within Microsoft Access. Microsoft Access is a very powerful client/server development tool. One of the SQL Server objects that you can interact with from within Microsoft Access…
Familiarize people with the process of utilizing SQL Server stored procedures from within Microsoft Access. Microsoft Access is a very powerful client/server development tool. One of the SQL Server objects that you can interact with from within Micr…

751 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