Search code examples
springoracle-databaseplsqlspring-data-jpaspring-jdbc

Quickest way to copy over table data in oracle/postgresql


I'm looking at a spring boot application that is used to copy data from temp to permanent table based on last updated date. It copies only if last updated date is greater than desired date, so not all records are copied over. Currently the table has around 300K+ records and the process with spring JPA is taking over 2 hours (for all of them) and is not at all feasible. The goal is to bring it down to under 15 mins maximum. I'm trying to see how much difference using JDBCtemplate would bring in. Would a pl/sql script be a better option? Also wanted to see if there are better options out there. Appreciate your time.

Using oracle database at the moment but postgresql migration is on the cards.

Thanks!


Solution

  • You can do this operation with a straight SQL query (which will work on Oracle or PostgreSQL). Assuming your temp_table has the same columns as the permanent table, the last updated date column is called last_updated and you wanted to copy all records updated since 2020-05-03 you could write a query like:

    INSERT INTO perm_table
    SELECT *
    FROM temp_table
    WHERE last_updated > TO_DATE('2020-05-03', 'YYYY-MM-DD')
    

    In your app you would pass '2020-05-03' via a placeholder either directly or via JdbcTemplate.