Skip to content

Instantly share code, notes, and snippets.

@onigra
Created October 26, 2012 01:52
Show Gist options
  • Save onigra/3956508 to your computer and use it in GitHub Desktop.
Save onigra/3956508 to your computer and use it in GitHub Desktop.
SQLでFIZZBUZZ(Oracle限定)
WITH
rowno AS (
SELECT
rownum no,
mod(rownum, 3) mod3,
mod(rownum, 5) mod5
FROM
dual
CONNECT BY
rownum < 16
),
fb AS (
SELECT no, 'fizzbuzz' AS fizzbuzz FROM rowno WHERE mod3 = 0 AND mod5 = 0
),
fi AS (
SELECT no, 'fizz' AS fizzbuzz FROM rowno WHERE mod3 = 0
),
bu AS (
SELECT no, 'buzz' AS fizzbuzz FROM rowno WHERE mod5 = 0
)
SELECT
rowno.no || fi.fizzbuzz || bu.fizzbuzz AS answer
FROM
rowno
LEFT JOIN
fb ON rowno.no = fb.no
LEFT JOIN
fi ON rowno.no = fi.no
LEFT JOIN
bu ON rowno.no = bu.no
ORDER BY
rowno.no
;
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment