Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • World
  • Users
  • Groups
Skins
  • Light
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
Code Project
  1. Home
  2. Database & SysAdmin
  3. Database
  4. How to find ladder in sql query

How to find ladder in sql query

Scheduled Pinned Locked Moved Database
databasehelptutorial
5 Posts 4 Posters 0 Views 1 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • M Offline
    M Offline
    Member 3567411
    wrote on last edited by
    #1

    Hi, I have table like below col1 5 10 15 20 I need result like Col1 Col2 5 05--9 10 10--14 15 15--19 20 20-24 Plz help Thank You Anil Banjare

    N V K 3 Replies Last reply
    0
    • M Member 3567411

      Hi, I have table like below col1 5 10 15 20 I need result like Col1 Col2 5 05--9 10 10--14 15 15--19 20 20-24 Plz help Thank You Anil Banjare

      N Offline
      N Offline
      Niral Soni
      wrote on last edited by
      #2

      How do you define ladder for the last value?? i.e. how do you get 24 in last row?? Apart from that, required query is -

      SELECT COL1, NVL2(NEXT_COL1, COL1 || '--' || (NEXT_COL1 - 1), NULL) COL2
      FROM (
      SELECT COL1
      ,LEAD(COL1, 1, NULL) OVER (ORDER BY COL1) AS NEXT_COL1
      FROM (SELECT LEVEL*5 COL1 FROM DUAL CONNECT BY LEVEL < 5)
      )
      ;

      And the output will be -

      COL1 COL2
      5 5--9
      10 10--14
      15 15--19
      20 NULL

      Thanks & Regards, Niral Soni

      K 1 Reply Last reply
      0
      • M Member 3567411

        Hi, I have table like below col1 5 10 15 20 I need result like Col1 Col2 5 05--9 10 10--14 15 15--19 20 20-24 Plz help Thank You Anil Banjare

        V Offline
        V Offline
        vassynet
        wrote on last edited by
        #3

        SELECT [col1],
        CONVERT(VARCHAR(10),[col1])+'--'+ CONVERT(VARCHAR(10),[col1] + 4) AS Col2
        FROM Table1

        1 Reply Last reply
        0
        • N Niral Soni

          How do you define ladder for the last value?? i.e. how do you get 24 in last row?? Apart from that, required query is -

          SELECT COL1, NVL2(NEXT_COL1, COL1 || '--' || (NEXT_COL1 - 1), NULL) COL2
          FROM (
          SELECT COL1
          ,LEAD(COL1, 1, NULL) OVER (ORDER BY COL1) AS NEXT_COL1
          FROM (SELECT LEVEL*5 COL1 FROM DUAL CONNECT BY LEVEL < 5)
          )
          ;

          And the output will be -

          COL1 COL2
          5 5--9
          10 10--14
          15 15--19
          20 NULL

          Thanks & Regards, Niral Soni

          K Offline
          K Offline
          karna from Hyderabad
          wrote on last edited by
          #4

          USE tempdb ; GO DECLARE @ladderTable TABLE ( Col1 INT ) ; DECLARE @incrementValue INT = 0 ; INSERT INTO @ladderTable ( Col1 ) VALUES ( 5 ), ( 10 ), ( 15 ), ( 20 ) ; SELECT TOP 1 @incrementValue = Col1 FROM @ladderTable ORDER BY Col1 ASC ; SELECT st.Col1, CAST(st.Col1 AS VARCHAR(20)) + ' - ' + CAST(ISNULL(dt.Col1, st.Col1 + @incrementValue) - 1 AS VARCHAR(20)) AS LadderSequence FROM @ladderTable AS st LEFT OUTER JOIN @ladderTable AS dt ON st.Col1 < dt.Col1 AND ( st.Col1 + @incrementValue ) >= dt.Col1 ; GO

          1 Reply Last reply
          0
          • M Member 3567411

            Hi, I have table like below col1 5 10 15 20 I need result like Col1 Col2 5 05--9 10 10--14 15 15--19 20 20-24 Plz help Thank You Anil Banjare

            K Offline
            K Offline
            karna from Hyderabad
            wrote on last edited by
            #5

            USE tempdb ; GO DECLARE @ladderTable TABLE ( Col1 INT ) ; DECLARE @incrementValue INT = 0 ; INSERT INTO @ladderTable ( Col1 ) VALUES ( 5 ), ( 10 ), ( 15 ), ( 20 ) ; SELECT TOP 1 @incrementValue = Col1 FROM @ladderTable ORDER BY Col1 ASC ; SELECT st.Col1, CAST(st.Col1 AS VARCHAR(20)) + '-' + CAST(ISNULL(dt.Col1, st.Col1 + @incrementValue) - 1 AS VARCHAR(20)) AS LadderSequence FROM @ladderTable AS st LEFT OUTER JOIN @ladderTable AS dt ON st.Col1 < dt.Col1 AND ( st.Col1 + @incrementValue ) >= dt.Col1 ; GO Thanks, Karunakar

            1 Reply Last reply
            0
            Reply
            • Reply as topic
            Log in to reply
            • Oldest to Newest
            • Newest to Oldest
            • Most Votes


            • Login

            • Don't have an account? Register

            • Login or register to search.
            • First post
              Last post
            0
            • Categories
            • Recent
            • Tags
            • Popular
            • World
            • Users
            • Groups