MyBatis注解方式之@Update/@Delete使用详解
@Update
1.RoleMapper接口增加接口方法
/** * * *@Title:updateSysRoleById * *@Description:updateSysRoleById * *@paramsysRole *@return * *@return:int */ @Update({"updatesys_rolesetrole_name=#{roleName},enabled=#{enabled},create_by=#{createBy},create_time=#{createTime,jdbcType=TIMESTAMP}whereid=#{id}"}) intupdateSysRoleById(SysRolesysRole);
2.单元测试
@Test publicvoidupdateSysRoleByIdTest(){ logger.info("updateSysRoleByIdTest"); //获取SqlSession SqlSessionsqlSession=getSqlSession(); try{ //获取RoleMapper接口 RoleMapperroleMapper=sqlSession.getMapper(RoleMapper.class); //先根据ID查询出对应的sysRole SysRolesysRole=roleMapper.selectSysRoleById((long)1); //roleName期望为管理员 Assert.assertEquals("管理员",sysRole.getRoleName()); //修改RoleName sysRole.setRoleName("管理员Artisan"); //修改CreateBy sysRole.setCreateBy("Artisan"); //修改用户,返回受影响的行数 intresult=roleMapper.updateSysRoleById(sysRole); //只插入一条数据,期望是1 Assert.assertEquals(1,result); logger.info("受影响的行数:"+result); //期望的RoleName为管理员Artisan Assert.assertEquals("管理员Artisan",sysRole.getRoleName()); //期望的CreateBy为Artisan Assert.assertEquals("Artisan",sysRole.getCreateBy()); logger.info("sysRole:"+sysRole); }catch(Exceptione){ e.printStackTrace(); }finally{ //为了保持测试数据的干净,这里选择回滚 //由于默认的sqlSessionFactory.openSession()是不自动提交的 //除非显式的commit,否则不会提交到数据库 sqlSession.rollback(); logger.info("为了保持测试数据的干净,这里选择回滚,不写入mysql,请观察日志,回滚完成"); sqlSession.close(); logger.info("sqlSessionclosesuccessfully"); } }
2018-04-1902:55:57,225INFO[main](BaseMapperTest.java:26)-sessionFactorybulitsuccessfully 2018-04-1902:55:57,230INFO[main](BaseMapperTest.java:29)-readerclosesuccessfully 2018-04-1902:55:57,233INFO[main](RoleMapperTest.java:229)-updateSysRoleByIdTest 2018-04-1902:55:57,726DEBUG[main](BaseJdbcLogger.java:145)-==>Preparing:SELECTa.id,a.role_nameroleName,a.enabled,a.create_bycreateBy,a.create_timecreateTimeFROMsys_roleaWHEREa.id=? 2018-04-1902:55:57,799DEBUG[main](BaseJdbcLogger.java:145)-==>Parameters:1(Long) 2018-04-1902:55:57,824TRACE[main](BaseJdbcLogger.java:151)-<==Columns:id,roleName,enabled,createBy,createTime 2018-04-1902:55:57,825TRACE[main](BaseJdbcLogger.java:151)-<==Row:1,管理员,1,1,2018-04-1321:12:46.0 2018-04-1902:55:57,828DEBUG[main](BaseJdbcLogger.java:145)-<==Total:1 2018-04-1902:55:57,829DEBUG[main](BaseJdbcLogger.java:145)-==>Preparing:updatesys_rolesetrole_name=?,enabled=?,create_by=?,create_time=?whereid=? 2018-04-1902:55:57,835DEBUG[main](BaseJdbcLogger.java:145)-==>Parameters:管理员Artisan(String),1(Integer),Artisan(String),2018-04-1321:12:46.0(Timestamp),1(Long) 2018-04-1902:55:57,839DEBUG[main](BaseJdbcLogger.java:145)-<==Updates:1 2018-04-1902:55:57,840INFO[main](RoleMapperTest.java:250)-受影响的行数:1 2018-04-1902:55:57,845INFO[main](RoleMapperTest.java:257)-sysRole:SysRole[id=1,roleName=管理员Artisan,enabled=1,createBy=Artisan,createTime=FriApr1321:12:46BOT2018,user=null,privilegeList=null] 2018-04-1902:55:57,849INFO[main](RoleMapperTest.java:267)-为了保持测试数据的干净,这里选择回滚,不写入mysql,请观察日志,回滚完成 2018-04-1902:55:57,851INFO[main](RoleMapperTest.java:270)-sqlSessionclosesuccessfully
@Delete
1.RoleMapper接口增加接口方法
/** * * *@Title:deleteSysRoleById * *@Description:deleteSysRoleById * *@paramid *@return * *@return:int */ @Delete("deletefromsys_rolewhereid=#{id}") intdeleteSysRoleById(Longid);
2.单元测试
@Test publicvoiddeleteSysRoleByIdTest(){ logger.info("deleteSysRoleByIdTest"); //获取SqlSession SqlSessionsqlSession=getSqlSession(); try{ //获取roleMapper接口 RoleMapperroleMapper=sqlSession.getMapper(RoleMapper.class); //调用删除接口 intresult=roleMapper.deleteSysRoleById((long)1); //期望影响的结果条数为1 Assert.assertEquals(1,result); //再次查询 SysRolesysRole=roleMapper.selectSysRoleById((long)1); //期望查询出来的sysRole为null Assert.assertNull(sysRole); }catch(Exceptione){ e.printStackTrace(); }finally{ //为了保持测试数据的干净,这里选择回滚 //由于默认的sqlSessionFactory.openSession()是不自动提交的 //除非显式的commit,否则不会提交到数据库 sqlSession.rollback(); logger.info("为了保持测试数据的干净,这里选择回滚,不写入mysql,请观察日志,回滚完成"); sqlSession.close(); logger.info("sqlSessionclosesuccessfully"); } }
2018-04-1902:56:23,024INFO[main](BaseMapperTest.java:26)-sessionFactorybulitsuccessfully 2018-04-1902:56:23,027INFO[main](BaseMapperTest.java:29)-readerclosesuccessfully 2018-04-1902:56:23,030INFO[main](RoleMapperTest.java:276)-deleteSysRoleByIdTest 2018-04-1902:56:23,517DEBUG[main](BaseJdbcLogger.java:145)-==>Preparing:deletefromsys_rolewhereid=? 2018-04-1902:56:23,589DEBUG[main](BaseJdbcLogger.java:145)-==>Parameters:1(Long) 2018-04-1902:56:23,596DEBUG[main](BaseJdbcLogger.java:145)-<==Updates:1 2018-04-1902:56:23,599DEBUG[main](BaseJdbcLogger.java:145)-==>Preparing:SELECTa.id,a.role_nameroleName,a.enabled,a.create_bycreateBy,a.create_timecreateTimeFROMsys_roleaWHEREa.id=? 2018-04-1902:56:23,599DEBUG[main](BaseJdbcLogger.java:145)-==>Parameters:1(Long) 2018-04-1902:56:23,625DEBUG[main](BaseJdbcLogger.java:145)-<==Total:0 2018-04-1902:56:23,628INFO[main](RoleMapperTest.java:299)-为了保持测试数据的干净,这里选择回滚,不写入mysql,请观察日志,回滚完成 2018-04-1902:56:23,631INFO[main](RoleMapperTest.java:302)-sqlSessionclosesuccessfully
补充知识:Mybatis注解大全Mybatis支持的所有注解说明
注解 | 使用对象 | 相对应的XML | 描述 |
---|---|---|---|
@CacheNamespace | 类 | 为给定的命名空间(比如类)配置缓存。属性有:implemetation,eviction,flushInterval,size,readWrite,blocking和properties。 | |
@Property | N/A | 指定参数值或占位值(placeholder)(能被mybatis-config.xml内的配置属性覆盖)。属性有:name,value。(仅在MyBatis3.4.2以上版本生效) | |
@CacheNamespaceRef | 类 | 参照另外一个命名空间的缓存来使用。属性有:value,name。如果你使用了这个注解,你应设置value或者name属性的其中一个。value属性用于指定Java类型而指定命名空间(命名空间名就是指定的Java类型的全限定名),name属性(这个属性仅在MyBatis3.4.2以上版本生效)直接指定了命名空间的名字。 | |
@ConstructorArgs | 方法 | 收集一组结果传递给一个结果对象的构造方法。属性有:value,它是形式参数数组。 | |
@Arg | N/A | 单参数构造方法,是ConstructorArgs集合的一部分。属性有:id,column,javaType,jdbcType,typeHandler,select和resultMap。id属性是布尔值,来标识用于比较的属性,和 |
|
@TypeDiscriminator | 方法 | 一组实例值被用来决定结果映射的表现。属性有:column,javaType,jdbcType,typeHandler和cases。cases属性是实例数组。 | |
@Case | N/A | 单独实例的值和它对应的映射。属性有:value,type,results。results属性是结果数组,因此这个注解和实际的ResultMap很相似,由下面的Results注解指定。 | |
@Results | 方法 | 结果映射的列表,包含了一个特别结果列如何被映射到属性或字段的详情。属性有:value,id。value属性是Result注解的数组。这个id的属性是结果映射的名称。 | |
@Result | N/A | 在列和属性或字段之间的单独结果映射。属性有:id,column,javaType,jdbcType,typeHandler,one,many。id属性是一个布尔值,来标识应该被用于比较(和在XML映射中的 |
|
@One | N/A | 复杂类型的单独属性值映射。属性有:select,已映射语句(也就是映射器方法)的全限定名,它可以加载合适类型的实例。fetchType会覆盖全局的配置参数lazyLoadingEnabled。注意联合映射在注解API中是不支持的。这是因为Java注解的限制,不允许循环引用。 | |
@Many | N/A | 映射到复杂类型的集合属性。属性有:select,已映射语句(也就是映射器方法)的全限定名,它可以加载合适类型的实例的集合,fetchType会覆盖全局的配置参数lazyLoadingEnabled。注意联合映射在注解API中是不支持的。这是因为Java注解的限制,不允许循环引用 | |
@MapKey | 方法 | ?? | 这是一个用在返回值为Map的方法上的注解。它能够将存放对象的List转化为key值为对象的某一属性的Map。属性有:value,填入的是对象的属性名,作为Map的key值。 |
@Options | 方法 | 映射语句的属性 | 这个注解提供访问大范围的交换和配置选项的入口,它们通常在映射语句上作为属性出现。Options注解提供了通俗易懂的方式来访问它们,而不是让每条语句注解变复杂。属性有:useCache=true,flushCache=FlushCachePolicy.DEFAULT,resultSetType=DEFAULT,statementType=PREPARED,fetchSize=-1,timeout=-1,useGeneratedKeys=false,keyProperty="",keyColumn="",resultSets=""。值得一提的是,Java注解无法指定null值。因此,一旦你使用了Options注解,你的语句就会被上述属性的默认值所影响。要注意避免默认值带来的预期以外的行为。注意:keyColumn属性只在某些数据库中有效(如Oracle、PostgreSQL等)。请在插入语句一节查看更多关于keyColumn和keyProperty两者的有效值详情。 |
@Insert@Update@Delete@Select | 方法 | 这四个注解分别代表将会被执行的SQL语句。它们用字符串数组(或单个字符串)作为参数。如果传递的是字符串数组,字符串之间先会被填充一个空格再连接成单个完整的字符串。这有效避免了以Java代码构建SQL语句时的“丢失空格”的问题。然而,你也可以提前手动连接好字符串。属性有:value,填入的值是用来组成单个SQL语句的字符串数组。 | |
@InsertProvider@UpdateProvider@DeleteProvider@SelectProvider | 方法 | 允许构建动态SQL。这些备选的SQL注解允许你指定类名和返回在运行时执行的SQL语句的方法。(自从MyBatis3.4.6开始,你可以用CharSequence代替String来返回类型返回值了。)当执行映射语句的时候,MyBatis会实例化类并执行方法,类和方法就是填入了注解的值。你可以把已经传递给映射方法了的对象作为参数,“Mapperinterfacetype”和“Mappermethod”and“DatabaseID”会经过ProviderContext(仅在MyBatis3.4.5及以上支持)作为参数值。(MyBatis3.4及以上的版本,支持多参数传入)属性有:type,method。type属性需填入类。method需填入该类定义了的方法名(Since3.5.1,youcanomitmethodattribute,theMyBatiswillresolveatargetmethodviatheProviderMethodResolverinterface.Ifnotresolvebyit,theMyBatisusethereservedfallbackmethodthatnamedprovideSql)。注意接下来的小节将会讨论类,能帮助你更轻松地构建动态SQL。 | |
@Param | 参数 | N/A | 如果你的映射方法的形参有多个,这个注解使用在映射方法的参数上就能为它们取自定义名字。若不给出自定义名字,多参数(不包括RowBounds参数)则先以“param”作前缀,再加上它们的参数位置作为参数别名。例如#{param1},#{param2},这个是默认值。如果注解是@Param("person"),那么参数就会被命名为#{person}。 |
@SelectKey | 方法 | 这个注解的功能与 |
|
@ResultMap | 方法 | N/A | 这个注解给@Select或者@SelectProvider提供在XML映射中的 |
@ResultType | 方法 | N/A | 此注解在使用了结果处理器的情况下使用。在这种情况下,返回类型为void,所以Mybatis必须有一种方式决定对象的类型,用于构造每行数据。如果有XML的结果映射,请使用@ResultMap注解。如果结果类型在XML的 |
@Flush | 方法 | N/A | 如果使用了这个注解,定义在Mapper接口中的方法能够调用SqlSession#flushStatements()方法。(Mybatis3.3及以上) |
以上这篇MyBatis注解方式之@Update/@Delete使用详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。