本篇博客是对项目开发中出现的单表的更新接口有9个之多的问题进行的总结并进行的改进。目的是将经历转变为自己的经验。通过博客的方式分享给大家,大家一起共同进步和提高。
在项目开发过程中,出现了对单表的更新接口出现了9个之多,虽然这些接口能够满足功能需要,但是没有丝毫的复用思想,以及后续对于接口的维护的工作量又很大。所以不是一个很好的设计。
那么我们如何对这个问题进行优化和解决,我们可以通过一个接口来替换调绝大多数的接口,通过使用mybatis的动态SQL实现。
下面是实现的例子。
准备一个java 的maven项目并集成mybatis使用mysql数据库
由于我将mapper的xml文件写在了java的目录中,所以配置了maven的构建
mysql mysql-connector-java 5.1.47 org.mybatis mybatis 3.5.2 junit junit 4.12 test src/main/java **/*.xml false
这里注意将自己数据库机器的ip地址和对应的库名写对,不然无法连接自己的数据库。
需要注意的是配置里面的实体路径的设置,和绑定的接口路径,如果路径不一致会报错。
package utils;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;import java.io.IOException;
import java.io.InputStream;public class MybatisUtils {private static SqlSessionFactory sqlSessionFactory;//静态代码块:一旦初始化就加载static{try {//使用Mybatis第一步:获取sqlSessionFactory对象//获取资源,直接读到mybatis-config.xmlString resource = "mybatis-config.xml";//需要用到输入流(InputStream) 把resource类加载进来InputStream inputStream = Resources.getResourceAsStream(resource);//通过build把输入流加载进来sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);} catch (IOException e) {e.printStackTrace();}}public static SqlSession getSqlSession() {//openSession中有自动commit(提交)事务的方法,加上true就能实现return sqlSessionFactory.openSession(true);}
}
通过编写通用的SQL语句,可以覆盖上文提到的八个更新语句。
update arpro_user_course_group_configurationinfo_id = #{reviseParam.infoId} course_id = #{reviseParam.courseId} class_id = #{reviseParam.classId} group_id = #{reviseParam.groupId} type = #{reviseParam.type} is_delete = #{reviseParam.isDelete} remark = #{reviseParam.remark} is_like = #{reviseParam.isMostLike} where is_delete = 0 and info_id = #{conditionParam.infoId} and course_id = #{conditionParam.courseId} and class_id = #{conditionParam.classId} and group_id = #{conditionParam.groupId} and is_like = #{conditionParam.isLike} and type = #{conditionParam.type}
UPDATE arpro_user_course_group_configurationset group_id = #{newGroupId}WHEREgroup_id = #{oldGroupId} andtype = #{type} UPDATE arpro_user_course_group_configurationSET is_delete=1WHERE class_id = #{classId}AND course_id = #{courseId} UPDATE arpro_user_course_group_configurationSET is_delete=1WHERE course_id = #{courseId} UPDATE arpro_user_course_group_configurationset group_id = #{groupCourseModel.newGroupId} ,is_like = #{isLike}WHEREtype = #{groupCourseModel.type} and class_id = #{groupCourseModel.classId} and course_id = #{groupCourseModel.courseId} and info_id =#{groupCourseModel.infoId} UPDATE arpro_user_course_group_configurationset is_like = #{isLike}where group_id = #{groupId} and type = #{type} UPDATE arpro_user_course_group_configurationset is_like = 1where info_id = #{infoId} and type = #{type} and group_id != #{groupId} and is_delete = 0 UPDATE arpro_user_course_group_configurationset is_like = 0where info_id = #{infoId} and type = #{type} and group_id = #{groupId} and is_delete = 0 UPDATE arpro_user_course_group_configurationset group_id = #{newGroupId} ,info_id = #{newInfoId}WHEREtype = 1 and class_id = #{classId} and course_id = #{courseId} and info_id = #{oldInfoId}
update `arpro_user_course_group_configuration` set is_delete =1 WHERE course_id=#{courseAndStudentInfoModel.courseId} AND class_id=#{courseAndStudentInfoModel.classId} ANDinfo_id IN#{student}
@Testpublic void test(){//获取数据库连接SqlSession sqlSession = MybatisUtils.getSqlSession();UserCourseGroupConfigurationMapper userCourseGroupConfigurationMapper = sqlSession.getMapper(UserCourseGroupConfigurationMapper.class);//进行更新操作UserCourseGroupConfigurationPojo reviseParam = new UserCourseGroupConfigurationPojo();UserCourseGroupConfigurationPojo conditionParam = new UserCourseGroupConfigurationPojo();reviseParam.setGroupId(new BigInteger("369279349968338943"));conditionParam.setGroupId(new BigInteger("369279349968338944"));conditionParam.setType(0);//更新分组iduserCourseGroupConfigurationMapper.updateCourseGroupConfiguration(reviseParam,conditionParam);}
通过编写通用的更新接口,可以进8个更新接口进行覆盖,相当于其他八个更新接口不用写了,用这一个通用更新接口就ok了。通过编写通用接口的方式,能够减少相当大的重复用编码的量。不仅利于后期谓语,也提高了编码效率。
在进行开发之前一定需要做好设计工作,编写代码时考虑如何进行高复用,低维护,高扩充。以此来提高开发效率和降低维护成本。
1.不怕不知道就怕不知道,怕就怕在根本不知道可以通过使用mybatis动态SQL的方式来让代码的可复用更强。
2. 具有复用思想,能够产生量变。