Data normalization

From SQLZoo

To select the data from 20 different columns into one changing the values according to one other column consisting the positions of the 20 columns.

schema:scott

Sometimes we have un-normailsed data that we want to normalise. Suppose we have data in 20 columns F1 to F20:

Line    F1    F2   F3   F4 ...
------------------------------
A       11    10   13   15 ...
B       20    22   23   28 ...

But we want a table that has just one data column. Like this...

Line   Col   Val
----------------
A      1     11
A      2     10
A      3     13
A      4     15
...
B      1     20
B      2     22
B      3     23
B      4     28
...

You can use INSERT ... SELECT ... statement

DROP TABLE normal
DROP TABLE unnormal;
CREATE TABLE unnormal
  (Line CHAR(1) PRIMARY KEY,
   F1 INTEGER,
   F2 INTEGER,
   F3 INTEGER,
   F4 INTEGER);
--Put the bad data in
INSERT INTO unnormal VALUES
 ('A', 11, 10, 13, 15);
INSERT INTO unnormal VALUES
 ('B', 20, 22, 23, 28);
--Create the good table
CREATE TABLE normal
 (Line CHAR(1), col INTEGER, val INTEGER,
  PRIMARY KEY (Line, col) );
--Copy the data into it
INSERT INTO normal(Line, col, val)
  SELECT Line, 1, F1 FROM unnormal
UNION
  SELECT Line, 2, F2 FROM unnormal
UNION
  SELECT Line, 3, F3 FROM unnormal
UNION
  SELECT Line, 4, F4 FROM unnormal;
SELECT * FROM normal;