EntityManger flushmode in JDBC

前端 未结 1 1461
不思量自难忘°
不思量自难忘° 2021-01-17 01:34

JPA is essentially an higher abstraction of JDBC. EntityManager has an API setAutoFlushMode. It can be set to AUTO or COMMIT. What\'s th equivalent of this in JDBC terms

1条回答
  •  旧巷少年郎
    2021-01-17 02:04

    JDBC has auto commit as well.

    They're both for configuring whether the library should automatically commit to the database.

    JDBCs auto-commit is very simplistic, it will commit every update to the database immediately. Without auto-commit, changes aren't committed until the commit method is called.

    JPA AUTO causes a flush to the database before a query is executed. Simple operations like find don't require a flush since the library can handle the search, however queries would be much more complicated, and so if AUTO is set, it will flush it first. If the mode is set to COMMIT, it will only flush the changes to the database upon a call to commit or flush. If COMMIT is set, and a query is run, it will not return results that have not been flushed.

    0 讨论(0)
提交回复
热议问题