1. 程式人生 > >oracle資料庫中使用hibernate生成表不能正確建立表

oracle資料庫中使用hibernate生成表不能正確建立表

最近在專案中使用hibernate的動態生成表,即將hbm2ddl.auto配置成update時,發現hibernate並沒有按照預設的生成規則生成相應的資料表資訊。但奇怪的是,只是部分表沒有生成,而其它的表即生成成功了。重新啟動專案,發現問題依舊。奇怪的是,雖然有些表沒有生成,但它相關聯的關聯表即生成了,而且在生成時,會報一個找不到相關的引用表的錯誤。報的錯誤如下:

 

2014-09-28 01:25:56 [org.hibernate.tool.hbm2ddl.SchemaUpdate]-[ERROR] Unsuccessful: alter table r_role_x_menu add constraint FK474DC862E1A553E2 foreign key (menu_id) references p_menu
2014-09-28 01:25:56 [org.hibernate.tool.hbm2ddl.SchemaUpdate]-[ERROR] ORA-00942: 表或檢視不存在

 找了半天,最後發現一個問題,即這裡需要引用的表p_menu在另一個使用者空間裡已經存在了,而hibernate在建立表時,在另一個使用者空間中找到了這個表,故不再在當前的使用者空間中建立這個表了。而在建立關聯表時,由於關聯的是本使用者空間的表,故有此錯誤。
hibernate使用了jdbc預設的databasemeta來尋找相應表資料資訊,當使用預設的配置時,由於某種原因(並不是每次都能發生,取決於資料庫本身以及相應的驅動)。當使用當前使用者連線到資料庫時,使用databasemeta尋找資料庫表資訊時,會查詢出其它使用者的資料表資訊(即使當前使用者沒有相應的許可權)。
解決此問題的方法很簡單,只需要在hibernate.cfg.xml中配置一句:

 

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

 

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