您好,登錄后才能下訂單哦!
mybatis plus使用insert時(shí)沒有返回主鍵怎么解決?很多新手對此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。
項(xiàng)目使用springboot搭建。最初的時(shí)候是使用mybatis,后來升級到mybatis plus。按照mp的官網(wǎng)介紹,使用mp的insert方法,對于自增的數(shù)據(jù)庫表,mp會(huì)把主鍵寫入回實(shí)例的對應(yīng)屬性。但實(shí)際操作起來,卻沒有主鍵。
entity 類設(shè)置如下:
@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 類設(shè)置如下:
@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)查了下,其他人都是這樣設(shè)置,就會(huì)有主鍵返回。
看到dao類里面一條注釋,// int insert(UserInfo record); ,心里有個(gè)想法。
這條注釋對應(yīng)的insert方法,是使用mybatis generator生成的。但是因?yàn)榇朔椒蚼ybatis plus的通用方法名一樣,所以我把它注釋了。會(huì)不會(huì)是因?yàn)閐ao對應(yīng)的mapper.xml文件,里面的id = inesert的sql語句依然存在,從而覆蓋掉了mybatis plus的通用insert,所以沒有自動(dòng)返回主鍵。
點(diǎn)進(jìn)去對應(yīng)mapper.xml文件,果然看到<insert id="insert">的sql語句。刪掉該語句,重試mybatis plus的insert方法,這次有主鍵返回了。
看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進(jìn)一步的了解或閱讀更多相關(guān)文章,請關(guān)注億速云行業(yè)資訊頻道,感謝您對億速云的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。