第一個 Mybatis程式--測試中可能遇到的問題以及解決方案
Mybatis程式,測試中可能遇到的問題以及解決方案:
-
錯誤一:找不到mybatis配置檔案java.io.IOException: Could not find resource org/mybatis/example/mybatis-config.xml
解決方案:
在pom.xml中增加build
<build> <resources> <resource> <directory>src/main/resources</directory> <includes> <include>**/*.properties</include> <include>**/*.xml</include> </includes> <filtering>false</filtering> </resource> <resource> <directory>src/main/java</directory> <includes> <include>**/*.properties</include> <include>**/*.xml</include> </includes> <filtering>false</filtering> </resource> </resources> </build>
如果該方法仍然無法解決找不到配置檔案的話,(1)再注意自己的mapper檔案,在mybatis-config.xml配置檔案中有沒有註冊;(2)檢視自己的mybatis的工具類(MybatisUtils.java)中resources 的路徑寫的是否正確
-
錯誤二: java.lang.ExceptionInInitializerError
在mapper.xml檔案中寫了中文註釋,導致報錯
解決方案:將標頭檔案中的
encoding="UTF-8"
改成UTF8重新執行後問題解決
-
錯誤三:
org.apache.ibatis.exceptions.PersistenceException:
Error querying database. Cause: com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure資料庫連線問題
解決方案:
將mybatis-config.xml核心配置檔案中
useSSL=true
改成false後問題解決<property name="url" value="jdbc:mysql://localhost:3305/mybatis?serverTimezone=GMT&useSSL=true&useUnicode=true&characterEncoding=utf-8"/>
-
錯誤四:
org.apache.ibatis.binding.BindingException: Type interface com.lyl.dao.UserDao is not known to the MapperRegistry.
UserMapper.xml檔案中,namespace名稱空間繫結問題
<mapper namespace="com.lyl.dao.UserDao">
解決方案:
檢視自己的Dao/Mapper介面包的路徑是否正確(路徑要從java資料夾下開始寫,com.xx.xx),修改正確後即可。