Asked By
Hansey
280 points
N/A
Posted on - 05/12/2011
Hi,
I am assigned for normalizing an established database written in MySQL. The database consists of only 1 table, with about 18 columns. All of them having information about the members(personal detail), their address, and job detail. I exported the database to Oracle with some effort, but I do not know how to divide this big table to 3 smaller ones. Here is the main table:
Â
ID VARCHAR2(500),
NAME VARCHAR2(500),
ADDR VARCHAR2(500),
AREA_CODE VARCHAR2(500),
TEL VARCHAR2(100),
AINS VARCHAR2(100),
YEARPASS VARCHAR2(100),
CENTRE VARCHAR2(500),
DOP VARCHAR2(100),
DUES VARCHAR2(100),
DIPNO VARCHAR2(100),
CODE VARCHAR2(100),
DEPT VARCHAR2(100),
DOB VARCHAR2(100),
GENDER VARCHAR2(100),
EMAIL VARCHAR2(100),
RELIGION VARCHAR2(100),
FAX VARCHAR2(100),
FOREIGN VARCHAR2(100),
MEM_ID NUMBER
Â
I have designed the children tables as follows. They will also use lookup tables, for National ID, Department etc.
Â
CREATE TABLE PERSONNEL (
ID NUMBER,
MEM_NO VARCHAR2(50),
NAME VARCHAR2(50),
TEL VARCHAR2(50),
GENDER NUMBER,
ADDRESS VARCHAR2(500),
AREA NUMBER,
DOB DATE,
EMAIL VARCHAR2(50),
RELIGION NUMBER,
FAX VARCHAR2(50)
)
Â
CREATE TABLE professional_detail(
Id NUMBER,
Ains NUMBER,
Year pass NUMBER,
Centre NUMBER,
Dipno VARCHAR2(30),
Code NUMBER,
Dept NUMBER
)
Â
CREATE TABLE ACCOUNT_INFO(
ID NUMBER,
DUE VARCHAR2(10),
DOP DATE
)
Â
Problem is that some of the columns in the big table is NULL and almost all of them do not follow any typical rule. I tried to create a procedure just to handle them but it seems to be a very ugly routine, to add all these (53,000) records by just hand coding. Even when I do so, the NULL values seem to cause a lot of trouble. The insertion does not work at all. Please help.
Help Normalizing a Big Table to 3 Sub Tables
Â
It looks like you are using look up tables in some places. If the mother table has NULL values in such fields, you have to handle them first. Try doing something like this:
Â
Add a field to each of the lookup tables "UNKNOWN" and key value 0 (i am guessing you haven't used 0 any were else). Run a update statement to mother table altering all the null fields to 0. This way you can avoid NULL values. You have not mentioned in you post how you populated the lookup tables.
Â
If you populated it manually then you have to make sure all the values are there. But it is more convenient to do some procedure like this to populate the lookups. I am writing this assuming that you have a lookup table for area named l_area with columns(a_id,area).
Â
CREATE VIEW VU_AREA AS SELECT DISTINCT(area_code) FROM main_TBL ORDER BY area_code;
Â
CREATE SEQUENCE sq_buf
START WITH 1
INCREMENT BY 1
CACHE 20 ;
Â
INSERT INTO l_area (a_id,area) SELECT sq_buf.NEXTVAL,area_code FROM VU_AREA;
Â
DROP SEQUENCE SQ_BUF;
Â
This shall auto populate the lookup table.
Answered By
Hansey
280 points
N/A
#91965
Help Normalizing a Big Table to 3 Sub Tables
Thanks very, very much for the informative and elaborate answer. I finally managed to organize the work. Now I have my lookup tables ready and main table fixed with NULL values replaced by 0.
Â
The three tables are created with appropriate size and data type. Now I need to take one row at a time from the main table ( "main_tbl" i call it.) And add the appropriate rows to each of them. All three of them have the ID column as common. I am doing something like this:
Â
Insert into personnel(
Â
ID,
MEM_NO,
NAME,
TEL,
GENDER,
ADDRESS,
AREA,
DOB,
EMAIL,
RELIGION,
FAX
)
Values(
Select
MEM_ID,
NAME,
TEL,
Getgender(GENDER),
ADDR,
GetArea(AREA_CODE),
EMAIL,
GetReligion(RELIGION)
From main_tbl
)
Â
Its not working. The functions getGender getArea are just used to fetch the key of the Specific Gender/Area in lookup table.
Help Normalizing a Big Table to 3 Sub Tables
You do not need the word VALUES, when inserting from another table. It would be:
Â
Insert into personnel(
ID,
MEM_NO,
NAME,
TEL,
GENDER,
ADDRESS,
AREA,
DOB,
EMAIL,
RELIGION,
FAX
)
Select(
MEM_ID,
NAME,
TEL,
Getgender(GENDER),
ADDR,
GetArea(AREA_CODE),
EMAIL,
GetReligion(RELIGION)
From main_tbl
)
Â
And yes, there is a multi-table insert function named INSERT ALL, which I think would be handy. Check out:
Â
Answered By
Hansey
280 points
N/A
#91967
Help Normalizing a Big Table to 3 Sub Tables
Â
Thanks a lot. I am truly amazed to have the job done in such less time! I have the whole week in front for free. Anyway just out of  curiosity I also tried multi table insert.
Â
INSERT ALL INTO PERSONNEL
(
……)
VALUES
(
………)
PROFESSIONAL_DETAIL
(
……)
VALUES
(
……)
ACCOUNT_INFO
(
…
Â
)
VALUES
(
…)
SELECT
 ……
FROM main_tbl
Â
It's not working, it's giving an error, "ORA-00936: missing expression".
Help Normalizing a Big Table to 3 Sub Tables
Â
You have to add the keyword, INTO to all of the insert commands:
Â
INSERT ALL INTO PERSONNEL
(—–
—–)
VALUES
(—-
—)
INTO PROFESSIONAL_DETAIL
(—-
—-)
VALUES
Â
—–
Â
——
Answered By
Hansey
280 points
N/A
#91969
Help Normalizing a Big Table to 3 Sub Tables
Thanks a lot. That would be very handy in future.
Help Normalizing a Big Table to 3 Sub Tables
You do not need the word VALUES, when inserting from another table. It would be:
Insert into personnel(
ID,
MEM_NO,
NAME,
TEL,
GENDER,
ADDRESS,
AREA,
DOB,
EMAIL,
RELIGION,
FAX
)
Select(
MEM_ID,
NAME,
TEL,
Getgender(GENDER),
ADDR,
GetArea(AREA_CODE),
EMAIL,
GetReligion(RELIGION)
From main_tbl
)
And yes, there is a multi-table insert function called INSERT ALL, which I think would be handy. You can check its proper syntax together with other Oracle Insert statements by visiting PSOUG.org | Oracle Insert Statements.