原 JAVA懒开发:对象虚拟化,全程无实体

直接对比

1、以前Mapper多表查询类似如下

<select id="getUserRolePage" parameterType="com.lazy.develop.model.UserRolQuery" 
	resultType="com.lazy.develop.model.UserRolePage">
	SELECT
		u.id,
		u.login_name AS loginName,
		u.`password`,
		u.create_time AS createTime,
		r.role_name AS roleName
	FROM
		`user` u
	JOIN role r ON u.`level` = r.id
	<where>
		<if test="startTime != null">
			u.create_time &gt;= #{startTime,jdbcType=TIMESTAMP}
		</if>
		<if test="endTime != null">
			AND u.create_time &lt;= #{endTime,jdbcType=TIMESTAMP}
		</if>
		<if test="level != null">
			AND u.level &gt; #{level,jdbcType=BIGINT}
		</if>
	</where>
</select>

这种情况多数,我们需要2个model(UserRolQuery和UserRolePage)

2、用Record.class(用map封装的)时如下

<select id="getUserRolePage" parameterType="com.lazy.develop.model.Record" 
	resultType="com.lazy.develop.model.Record">
	SELECT
		u.id,
		u.login_name AS loginName,
		u.`password`,
		u.create_time AS createTime,
		r.role_name AS roleName
	FROM
		`user` u
	JOIN role r ON u.`level` = r.id
	<where>
		<if test="startTime !='' and startTime != null">
			u.create_time &gt;= #{startTime,jdbcType=TIMESTAMP}
		</if>
		<if test="endTime !='' and endTime != null">
			AND u.create_time &lt;= #{endTime,jdbcType=TIMESTAMP}
		</if>
		<if test="level !='' and level != null">
			AND u.level &gt; #{level,jdbcType=BIGINT}
		</if>
	</where>
</select>

parameterType与resultType都是Record.class,但是因为是map,在取的时候都是字符串取值的,所以加空字符串判断。

3、service和serviceImpl都是一样的,只参数类与返回类不一样

4、以前的Controller

@RequestMapping(value="/getById", method = RequestMethod.GET)
public Object getUserRolePage(@ModelAttribute UserRolQuery userRolQuery){
	List<UserRolePage> user = userServiceImpl.getUserRolePage(userRolQuery);
	return user;
}

①一旦参数发生变化,UserRolQuery就的发生修改 ②一旦返回结果变化,UserRolePage也得发生修改 ③以上2中情况发生,Mapper配置文件都得改

5、使用Record.class的Controller

@RequestMapping(value="/getUserRolePage", method = RequestMethod.GET)
public Object getUserRolePage(HttpServletRequest request){
	Record Record=new Record(request);
	List<Record> user = userServiceImpl.getUserRolePage(Record);
	return user;
}

4中①和②的情况,都只需要执行步骤③

6、使用Record执行结果

给参数赋值什么的都不影响哈

Record赋值,取值

@RequestMapping(value="/getUserRolePage", method = RequestMethod.GET)
public Object getUserRolePage(HttpServletRequest request){
	Record record=new Record(request);
	//record.put("name", "name"); //和普通的map使用一样
	//String name=record.getString("name");
	//Integer id=record.getInteger("id");
	//Long id2=record.getLong("id");
	//Object obj=record.get("user"); //目前就写了这几个,大家可以根据自己的需求改哈
	
	List<Record> user = userServiceImpl.getUserRolePage(record);
	return user;
}

这种开发模式,因为没的bean,所以要求注释就比较严谨,不然过段时间,自己都不知道里面有啥了,不过对与有bean的来说,内容多的话,你也不知道那个字段在用,那个没用了吧,总体来说,优缺点都很明显。

Record.class源码:https://my.oschina.net/bianxin/blog/1589597

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏一个会写诗的程序员的博客

第16章 Spring Boot + Kotlin: 下一代 Java 服务端开发

2017-11-22 11:55:17.205 INFO 14721 --- [ main] org.hibernate.Version ...

1421
来自专栏哲学驱动设计

P of EAA 总结

看了几遍了,就只在书上勾了下,也没什么总结。暂且先把关键内容摘抄如下: Domain Logic Patterns Transaction Script Org...

2025
来自专栏向治洪

ssh搭建开发环境

公司一直不是ssh零配置的框架,每次写action都要在applicationcontext和struts里面配置,好麻烦,最近有空,写了一个ssh零配置的框架...

22410
来自专栏一个会写诗的程序员的博客

使用 layui 后端分页的实例

https://github.com/KotlinSpringBoot/saber

1092
来自专栏F_Alex

(三)SpringBoot2.0基础篇- 持久层,jdbcTemplate和JpaRespository

1793
来自专栏Hongten

Hibernate Annotation (Hibernate 注解)

英文:http://docs.jboss.org/hibernate/annotations/3.5/reference/en/html_single/

882
来自专栏岑玉海

RavenDb学习(六)查询补充特性

1、延迟加载 原来的查询方式如下: IEnumerable<User> users = session .Query<User>() .Wher...

2836
来自专栏Android相关

Android使用MultiDex发生ClassNotFoundException

在Method与Filed数超限的背景下,我们将多工程拆分成多个Dex打到Apk中解决该问题,但是在使用MultiDex的时候,还会遇到一些问题。 在启动的时...

1282
来自专栏猿天地

Spring Boot中快速操作Mongodb

在Spring Boot中集成Mongodb非常简单,只需要加入Mongodb的Starter包即可,代码如下:

3602
来自专栏后端之路

Spring的cache实现一

spring3.1之后引入了新的注解EnableTransactionManagement

2043

扫码关注云+社区