What are the JPA @Table annotation "catalog" and "schema" variables used for?

Sam Levin picture Sam Levin · Jun 25, 2012 · Viewed 24.3k times · Source

Why are these important, what effect do they have on the database at hand?

Isn't the "schema" already decided at that point, as it exists in the database?

What exactly is a "catalog"? What kind of variable/input is the JPA catalog field expecting? Also, same question for the "schema" field.

Answer

jpkrohling picture jpkrohling · Jun 25, 2012

Catalogs and schemas are "namespaces" that you define on the server side of the database. Some databases contains schemas, some contains catalogs, and some contains both. When logging in with a specific user, some databases defaults the schema/catalog to the user's namespace, causing the table to not be visible to other users, thus, causing the need to use a "common" namespace. So, depending on the database you are using to back your data, you might want to ignore those settings.

For MySQL, you might want to ignore those settings. This is because the "database" part of the JDBC URL (the one after the last slash) points to the database name, which is semantically identical to schema (for MySQL).