Want to protect your cyber security and still get fast solutions? Ask a secure question today.Go Premium

x
?
Solved

Sorting of number in PTO order

Posted on 2009-05-13
4
Medium Priority
?
393 Views
Last Modified: 2013-12-18
Hi ,

I have a table having  only one col. of varchar2 data type .
data are as follows :

1.2
2.0
2.21
8.0
2.2.1
3.0
4.1
3.1
5.1
3.2.4

I want to display is sorted order as :

1.2
2.0
2.2.1
2.21
3.0
3.1
3.2.4
4.1
5.1
8.0

How can I do it
in sql.

!Koushik
0
Comment
Question by:koushikonjob
  • 3
4 Comments
 
LVL 74

Expert Comment

by:sdstuber
ID: 24381927
that's an interesting question because your sample data is sortable  "as is"

select your_column from your_table order by your_column

however, on the assumption that you want to sort your data from left-to-right in numeric order by each dot delimited number then try this...

This could be simplified by using a function for comparing values

I've made the assumption here that you will never have more than 9 numeric pieces to your string if that's not correct then adjust "level < 10" to some number big enough
I've also assumed no one number will be greater than 99 , if that's not correct then adjust "power(100,"  to some number bigger than the largest segment number
 SELECT   str
    FROM   (SELECT   str,
                     cnt,
                     maxcnt,
                     n,
                     TO_NUMBER(SUBSTR(str, startpos, endpos - startpos + 1)) * POWER(100, maxcnt - n)
                         val
              FROM   (SELECT   str,
                               cnt,
                               MAX(cnt) OVER () maxcnt,
                               n,
                               DECODE(n, 1, 1, INSTR(str, '.', 1, n - 1) + 1) startpos,
                               DECODE(n, cnt, LENGTH(str), INSTR(str, '.', 1, n) - 1) endpos
                        FROM   (SELECT   str, LENGTH(str) - LENGTH(REPLACE(str, '.', NULL)) + 1 cnt
                                  FROM   yourtable) t,
                               (    SELECT   LEVEL n
                                      FROM   DUAL
                                CONNECT BY   LEVEL < 10)
                       WHERE   n <= cnt))
GROUP BY   str
ORDER BY   SUM(val)

Open in new window

0
 
LVL 74

Expert Comment

by:sdstuber
ID: 24394407
need anything else?
0
 

Author Comment

by:koushikonjob
ID: 24395806
Sorry for late reply... ya its working fine.....

Thanks!!
Koushik
0
 
LVL 74

Accepted Solution

by:
sdstuber earned 500 total points
ID: 24395851
glad I could help

I see this is your first question.  Welcome to  EE.

If you need nothing else on this topic then please close the question.
Accept the post with the answer and give a grade.
0

Featured Post

Become an Android App Developer

Ready to kick start your career in 2018? Learn how to build an Android app in January’s Course of the Month and open the door to new opportunities.

Question has a verified solution.

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

This post first appeared at Oracleinaction  (http://oracleinaction.com/undo-and-redo-in-oracle/)by Anju Garg (Myself). I  will demonstrate that undo for DML’s is stored both in undo tablespace and online redo logs. Then, we will analyze the reaso…
Occasionally there is a need to clean table columns, especially if you have inherited legacy data. There are obviously many ways to accomplish that, including elaborate UPDATE queries with anywhere from one to numerous REPLACE functions (even within…
This video explains what a user managed backup is and shows how to take one, providing a couple of simple example scripts.
This video shows how to copy an entire tablespace from one database to another database using Transportable Tablespace functionality.
Suggested Courses

580 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