MyBatis获取自动增长主键

方法一:selectKey

<!--主键id自动增长--<insertid="insertone"parameterType="com.model.User">                                                 
<selectKey  keyProperty="id" resultType="int" order="AFTER"><!--Order:相对于insert语句来说它的执行顺序-->                                                                                                                       
selectLAST_INSERT_ID()<!--得到刚insert进去记录的主键值,只适用于自增主键:主要作用就是获取自动增长的主键值-->                                                                                                                
</selectKey>                                                                                                                             
Insert into user(name,age) values(#{name},#{age})                                                              
</insert>                                                                                                                                   

方法二:useGeneratedKeys=“true”

<insert  id="inserttwo"  parameterType="com.model.User"  keyProperty="id"                useGeneratedKeys="true"> <!--主要作用就是获取自动增长的主键值-->                                        
Insert into user(name,age) values(#{name},#{age})                                                               
</insert>                                                                                                                                    

test:

public class Test {
	@org.junit.Test
	public void test(){
		InputStream  sq=null;
		try {
			sq=Resources.getResourceAsStream("SqlMapper.xml");
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		SqlSessionFactory sf=new SqlSessionFactoryBuilder().build(sq);
		SqlSession session=sf.openSession();
		//插入数据
		User user=new User();
		user.setName("coco");
		user.setAge(100);
		session.insert("test.insertplustwo",user);
		System.out.println(user.getId());

	}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值