1. 程式人生 > >hibernate生成表不能正確建立表的問題

hibernate生成表不能正確建立表的問題



hibernate在建立表時,在另一個使用者空間中找到了這個表,故不再在當前的使用者空間中建立這個表了。而在建立關聯表時,由於關聯的是本使用者空間的表,故有此錯誤。
hibernate使用了jdbc預設的databasemeta來尋找相應表資料資訊,當使用預設的配置時,由於某種原因(並不是每次都能發生,取決於資料庫本身以及相應的驅動)。當使用當前使用者連線到資料庫時,使用databasemeta尋找資料庫表資訊時,會查詢出其它使用者的資料表資訊(即使當前使用者沒有相應的許可權)。

<property name="default_schema">當前連線使用者</property
>

這樣,使用databasemeta時,就會強制性地在當前使用者空間中尋找資料庫資訊了,這樣就能正確的創建出表結構了。