詳解mybatis plus使用insert沒有返回主鍵的處理
項目使用springboot搭建。最初的時候是使用mybatis,后來升級到mybatis plus。按照mp的官網(wǎng)介紹,使用mp的insert方法,對于自增的數(shù)據(jù)庫表,mp會把主鍵寫入回實例的對應屬性。但實際操作起來,卻沒有主鍵。
entity 類設置如下:
@TableName(value = "USERINFO")
public class UserInfo {
/**
* 指定自增策略
*/
@TableId(value = "user_id",type = IdType.AUTO)
private Long userId;
private String gender;
private Date birthday;
private String phone;
//省略后面的其他屬性和getter/setter
}
dao 類設置如下:
@Repository
@Mapper
public interface UserInfoDao extends BaseMapper<UserInfo> {
// int insert(UserInfo record);
int insertSelective(UserInfo record);
UserInfo selectByPrimaryKey(Long logId);
int updateByPrimaryKeySelective(UserInfo record);
}
Service類調(diào)用userInfoDao的insert方法(此方法是來源于BaseMapper)。但是insert成功后沒有返回主鍵userId。上網(wǎng)查了下,其他人都是這樣設置,就會有主鍵返回。
看到dao類里面一條注釋,// int insert(UserInfo record); ,心里有個想法。
這條注釋對應的insert方法,是使用mybatis generator生成的。但是因為此方法名和mybatis plus的通用方法名一樣,所以我把它注釋了。會不會是因為dao對應的mapper.xml文件,里面的id = inesert的sql語句依然存在,從而覆蓋掉了mybatis plus的通用insert,所以沒有自動返回主鍵。
點進去對應mapper.xml文件,果然看到<insert id="insert">的sql語句。刪掉該語句,重試mybatis plus的insert方法,這次有主鍵返回了。
到此這篇關于詳解mybatis plus使用insert沒有返回主鍵的處理的文章就介紹到這了,更多相關mybatis plus insert沒有主鍵內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Springboot文件上傳出現(xiàn)找不到指定系統(tǒng)路徑的解決
這篇文章主要介紹了Springboot文件上傳出現(xiàn)找不到指定系統(tǒng)路徑的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08
springboot jpaRepository為何一定要對Entity序列化
這篇文章主要介紹了springboot jpaRepository為何一定要對Entity序列化,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12
Java封裝數(shù)組實現(xiàn)在數(shù)組中查詢元素和修改元素操作示例
這篇文章主要介紹了Java封裝數(shù)組實現(xiàn)在數(shù)組中查詢元素和修改元素操作,結(jié)合實例形式分析了java針對數(shù)組元素查詢、修改的封裝操作實現(xiàn)技巧,需要的朋友可以參考下2020-03-03
springcloud微服務基于redis集群的單點登錄實現(xiàn)解析
這篇文章主要介紹了springcloud微服務基于redis集群的單點登錄實現(xiàn)解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-09-09
親手教你IDEA2020.3創(chuàng)建Javaweb項目的步驟詳解
這篇文章主要介紹了IDEA2020.3創(chuàng)建Javaweb項目的步驟詳解,本文是小編手把手教你,通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2021-03-03

