解決報錯:Cause: java.sql.SQLSyntaxErrorException: Table 'myactiviti.act_ge_property' doesn't exist

錯誤如下:

在這裏插入圖片描述

解決辦法:
1.yml 配置時

配置mysql連接時加上:nullCatalogMeansCurrent=true

 url: jdbc:mysql://localhost:3306/myActiviti?useUnicode=true&characterEncoding=utf8&nullCatalogMeansCurrent=true&useSSL=false&useLegacyDatetimeCode=false&serverTimezone=UTC
2.xml配置時

在這裏插入圖片描述

問題出現的原因:

出現這種問題的原因是mysql版本問題,mysql8.xxx以上驅動會出現這個問題,下圖是我原mysql配置,是8.0.16的。
在這裏插入圖片描述

總結:

因爲mysql使用schema標識庫名而不是catalog,因此mysql會掃描所有的庫來找表,如果其他庫中有相同名稱的表,activiti就以爲找到了,本質上這個表在當前數據庫中並不存在。
設置nullCatalogMeansCurrent=true,表示mysql默認當前數據庫操作,在mysql-connector-java 5.xxx該參數默認爲true,在6.xxx以上默認爲false,因此需要設置nullCatalogMeansCurrent=true。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章