oracle使用hibernate不能自動建表

2021-08-11 14:13:40 字數 929 閱讀 3406

最近在專案中使用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中配置一句:

當前連線使用者

oracle資料庫表還原及hibernate連線

1 hibernate的連線oracle 把驅動程式class12.jar放到lib下了.2 hibernate裡的連線 oracle.jdbc.driver.oracledriver jdbc oracle thin localhost 1521 oracle system system 3 資料...

MyEclipse中刪除對Hibernate的支援

在myeclipse新增hibernate容易,刪除難,因為myeclipse中沒有刪除hibernate的功能鍵。但如果我們需要重新生成hibernate時,必須先徹底刪除hibernate支援。下面是手工刪除hibernate支援的方法 1.把專案根目錄下檔案.myhibernatedata刪除...

移除myeclipse中對hibernate的支援

在使用hibernate框架進行開發時可能會遇到配置錯誤或者需要刪除hibernate支援的情況。下面就說一下如何徹底移除專案的hibernate支援。移除後就能重新新增hibernate支援,重新配置了。1.找到你的專案的目錄 2.刪除.myhibernatedata檔案 3.找到.project...