时间:2021-05-19
我发现我所有有查询的controller都要调用service层的两个方法 getById和getByKey 参数大致一样
写的时候基本都是复制粘帖。。。 于是idea老提示大量重复代码 好烦啊 于是就改进了一下
让所有有关查询的service实现一个QueryService的接口
接口定义俩方法
import com.jfinal.plugin.activerecord.Page;public interface QueryService<T> { Page<T> getById(String id, String flag); Page<T> getByKey(int page, int pageSize, String value, String flag);}肯定要用泛型啊 不然强转容易出错 鬼知道我刚才调用的哪的这个方法
然后把service层的那些方法都统一一下参数
然后在一个公共控制器里写个静态方法 那个注解应该可以不用写 反正控制器不认静态方法
@NotActionstatic <T> Page<T> query(QueryService<T> service,Controller controller, String key, String value, String flag, int page, int pageSize) { value = value == null ? "" : value; Page<T> list; if ("id".equals(key)) { list = service.getById(value, flag); } else if ("key".equals(key)) { list = service.getByKey(page, pageSize, value, flag); } else { list = null; } if (list == null) { controller.renderJson("result", "{'code':'203','info':'unknown key'}"); } else { controller.renderJson("result", "{'code':'103','info':" + Json.getJson().toJson(list) + "}"); } return list;}用的时候在控制器里第一个写调用的service对象,这个service一定要实现QueryService接口,第二个就传this,因为查询结束要传给前台的,我也是懒,都写这里了
如果render不写这里的话就把第二个参数删掉,把12-16行的业务代码扔回控制器的方法里写
最后还返回list 我也不知道我想干啥 等我想开了就把返回值删掉算了
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
一对一查询在实际开发中,经常会遇到一对一查询,一对多查询等。这里我们先来看一对一查询。例如:每本书都有一个作者,作者都有自己的属性,根据这个,我来定义两个实体类
单表的唯一查询用:distinct多表的唯一查询用:groupbydistinct查询多表时,leftjoin还有效,全连接无效,在使用mysql时,有时需要查
基于Python2.7的版本环境,Python实现的数据库跨服务器(跨库)迁移,每以5000条一查询一提交,代码中可以自行更改每次查询提交数目.#-*-codi
有时候我们在查询数据库时,需要以查询结果为查询条件进行关联查询。在mybatis中通过association标签(一对一查询,collection一对多查询)实
使用springmvc提供restful风格的接口,实现前后端分离,后端只提供数据接口,而不做页面渲染。因此可对接口做统一处理:请求参数校验响应数据格式全局异常