??????????????????????????????????????????????????????????????????????????
?????????????????????????
* * *
?????????????????????????????????????DBMS??????????????????????????????DBMS?????????????????????????????????????????????
1. ????
?????????????????????????????????????????????????????????????????????1??????
????????????????
?????????????????????????????DB???????OSS?PostgreSQL?????AP?????DB???????????????????
????????
?????10?????????????GB????????????????????????????DB??????????????????????????
?????????????3,500?????????24?????????????????????????????????????
??AP?????????????????????????????????????????DB??PostgreSQL??????????????????PostgreSQL
????????????????????Vacuum?????????????????????????????????????????????????????
??????????????????PostgreSQL?OSS??????????????????????????????????????????????????DB
MS??????Oracle Database 11gR2???????????????????????500GB???????????????????????????Partitioning
???????? Oracle Database Enterprise Edition??????????????????????????????????????????????
????SAN?????Active/Standby???HA?????????????????
2. ?????
2.1. ????
PostgreSQL??????Oracle??????????????????????????????????????????????????????TEXT?????
????????????????????Oracle??????????????????????????PostgreSQL??csv???????Oracle Database?SQL*Loa
der?????????????
??????????????????????????????DB??????????????Windows?Liunx???????????????????????
?????????????????????????????????????????????????
?????????????PostgreSQL?NULL?????''????????????Oracle Database????????????????????????
??????????
table {
border-collapse: collapse;
}
th {
border: solid 1px #666666;
color: #000000;
background-color: #ff9999;
}
td {
border: solid 1px #666666;
color: #000000;
background-color: #ffffff;
}
????
PostgreSQL
Oracle Database
???
CHAR(n)
CHAR(n),CLOB
VARCHAR(n)
VARCHAR2(n),CLOB
TEXT
CLOB
???
NUMERIC
NUMBER
INTEGER
NUMBER
SMALLINT
NUMBER
BIGINT
NUMBER
REAL
NUMBER
DOUBLE PRECISION
NUMBER
???
DATE
DATE
TIMESTAMP
TIMESTAMP
?????
Bytea
BLOB
LOB
BFILE/SecureFiles
???
OID
ROWID
2.2. ?????
?????????????PostgreSQL?Oracle Database??????????SQL???????????????????????????????????Postg
reSQL?LIMIT?OFFSET??Oracle Database??????????????????????
LIMIT,OFFSET???SELECT??????
/* PostgreSQL LIMIT,OFFSET */
SELECT ???
FROM ?????
ORDER BY ????
LIMIT 2 OFFSET 5;
/* Oracle Database????? */
SELECT ???
FROM (SELECT ???,
ROWNUM line_no
FROM (SELECT???
FROM ?????
OREDR BY ????
)
)
WHERE line_no BETWEEN 6 AND 7;
???????????????????????????????????????????????????????????????????????????
??????????????????
????????????????????????????????????????????????Oracle Database??????????????????????Oracle Database????WHERE??????????????????????????????????????????????????????WHERE??????????????????????
3. ????
???????????????????????30%~40%????????????????????80%?????????????????????
?ITpro???:???????4?????
???????????????????????????????????
·?????·???????????????????????????
·?????????????????????????????
?????????????????????????????????????????
3.1. ???????
????????????????????????????????????????·???????????????????????????????????
???????????????????????????????????????????????????????·??????????????????
????????????????????????????
(1)????????????????????
(2)????????????????????????????????????????????
(3)???????????????
(4)????????????????????????????????
???????????·????????????????????????????????????????????????????????????????
?????????????????????
????????·??
table {
border-collapse: collapse;
}
th {
border: solid 1px #666666;
color: #000000;
background-color: #ff9999;
}
td {
border: solid 1px #666666;
color: #000000;
background-color: #ffffff;
}
??
??
??
(1)
??????????
????????????·????????????????????????
(2)
????????????????????
??????????????????????????????
(3)
?????4?????????????????
???????????????????????DB?????????
(4)
??????????(3)????????
????????????????????????
?????????????????????GB???????????????????????????????????????????(3)??????????
???????
??????????????????????????????????????????????csv??????????SQL*Loader?Oracle Database?????????????????????Oracle Database???????????????????????????INSERT?????????????
????????????????????????????????????????????????????????????????????????????
??????????????????????
3.2. ?????
????????????????????????????????????????????????????????????????????????????
?????????????????????????????????????????????????????????????????????????????????????????????
??????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????
3.3. ?????
???????????????????????????????????????????????????????????????????????????
???????????????????????
DBMS????????????????????????SQL??????????????????????????????????????????????????PostgreSQL?Oracle Database???????????MVCC?????????????????????????Read Committed???????????????????????????????????????????????????????????????????????????????????
????????????????DBMS??????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????
4. ???
PostgreSQL??Oracle Database??????????????????????????????
????????????·?????????????????????????????????????
??????4???????????????????????·???????????????????
????????????????????????????????????????????????
?????????????????????????????????????????????DBMS???????????????????DBMS????????
?????SQL?????????????????????????????DB????????????????????????????
???????????????????????????DBMS??????????????????????????????????????????????????????
??????????????????????????????