oracle數(shù)據(jù)庫慢 Oracle在插入大量數(shù)據(jù)時(shí)速度會(huì)越來越慢,請(qǐng)問有什么解決辦法?
Oracle在插入大量數(shù)據(jù)時(shí)速度會(huì)越來越慢,請(qǐng)問有什么解決辦法?為了加快Oracle數(shù)據(jù)庫的數(shù)據(jù)插入速度,方法:從編程的角度來看:1使用綁定變量實(shí)現(xiàn)一次預(yù)編譯、多次執(zhí)行的效果。如果不使用綁定變量,數(shù)據(jù)
Oracle在插入大量數(shù)據(jù)時(shí)速度會(huì)越來越慢,請(qǐng)問有什么解決辦法?
為了加快Oracle數(shù)據(jù)庫的數(shù)據(jù)插入速度,方法:
從編程的角度來看:
1使用綁定變量實(shí)現(xiàn)一次預(yù)編譯、多次執(zhí)行的效果。如果不使用綁定變量,數(shù)據(jù)庫每次都會(huì)分析SQL并消耗資源。
2使用Oracle提供的批處理接口,減少網(wǎng)絡(luò)傳輸次數(shù),提高效率
3適當(dāng)增加提交間隔,提交指令消耗更多數(shù)據(jù)庫資源,提交前盡量插入更多數(shù)據(jù)。1000多條建議。
4. 使用insert語句的hint(如append)和nologing選項(xiàng)來減少數(shù)據(jù)庫日志注冊(cè)。
5. 從數(shù)據(jù)庫的角度考慮使用多進(jìn)程插入或并行提示插入
1。將表更改為nologing模式,這樣就不需要注冊(cè)回滾日志了
2。對(duì)表進(jìn)行分區(qū),使不同的分區(qū)落在不同的硬盤上
3。刪除表的索引,插入數(shù)據(jù)后還原
4。增加數(shù)據(jù)庫緩沖區(qū)
5使用SSD存儲(chǔ)和其他高效硬盤作為數(shù)據(jù)庫存儲(chǔ)
其他詳細(xì)信息:
例如,將程序部署到數(shù)據(jù)庫服務(wù)器,然后進(jìn)行操作以減少網(wǎng)絡(luò)消耗
插入數(shù)據(jù),程序輸出日志重定向到硬盤
萬級(jí)數(shù)據(jù)確實(shí)不大,只需使用一些常用的同步,創(chuàng)建一個(gè)dblink,然后使用merge,兩個(gè)庫中的主鍵如果不一樣,就可以從對(duì)方的庫中拉出來(insert操作)。如果相同,則可以更新(更新操作)
或使用觸發(fā)器。當(dāng)數(shù)據(jù)發(fā)生變化時(shí),它將自動(dòng)執(zhí)行相應(yīng)的操作并將其寫入另一方的庫中。