java实现通用查询_自己设计一个 JAVA + MyBatis 解析实体类多表通用查询

先来处理一下查询的字段和用到的表吧

//虽然我们使用的时候是实体,但最终还是要解析成sql的,那么我们需要想好解析成sql 时候所用到的东东,提前准备好

class TableEntity {

String tableName; //表的真正名称肯定是要的

String nickName; //表名的重命名也是要的, 去掉真名的表的下划线的全英文字母

String idName; //表的主键名称肯定是要的

String logicName; //上面定义了逻辑删除功能,所以这个逻辑删除也要

List entityColumns; //实体的字段

List tableColumns; //与实体字段一对一的数据表的字段

Object entity; //与之相关的实体

}

//现在用到数据表实体已经定义好了,是不是要写个工具将传入的实体参数解析成 TableEntity 了呢

class TableUtil {

TableEntity toTableEntity(Object entity); //将实体解析成TableEntity

//...

}

//已经有了数据表的描述,那么我们将selectColumns 解析成 sql 的 select 字段完全没有问题了吧

//将 "user.UserId, user.userName, address.detail, orders" 解析

// ',' 分割去空格, '.' 前后的替换为 nickName,'.' 后面替换为数据表的字段,单独的 orders 替换为 nickName.[every tableColumn]

class TableUtil {

TableEntity toTableEntity(Object entity); //将实体解析成TableEntity

//添加一个工具来实现吧

String toNativeSelectColumns(String SelectColumns);

}

那么我们再来看看如何实现表的连接吧

/**

传过来是这样的参数: new User(), new Address(), new Orders()

简单的约束弄: 找到 User 表的主键(@TableId) 字段的Field名, 匹配 Address中的 Filed名,找到了那么说明用此字段关联,同样的方式, 循环向后寻找即可找到所有关联。但是这样的简单的定义约束。user表的主键需要为user_id, address表的与user表关联的字段 必需也要叫user_id,关联的字段名必须取一样的名称,如果想不一样,可以使用注解,这里先不作介绍。

*/

//那么工具类又新增方法, 这里只作Left Join

class TableUtil {

TableEntity toTableEntity(Object entity); //将实体解析成TableEntity

//添加一个工具来实现吧

String toNativeSelectColumns(String SelectColumns);

//添加left join 方法

List toLeftJoin(Object ...entities);

}

现在已经解决了查找的字段与自动关联的问题,那么接下来是如何条件查询了, 前面我们已经定义了 WhereCustomSegment 类了,完善一个思路吧

class WhereCustomSegment {

public WhereCustomSegment(TableEntity ...tableEntities); //构造,我们需要关于数据表的全部信息

WhereCustomSegment where(String tableName);

}

//那么如何实现一个like 方法呢? 如: like("userName", "whoareyou")

//了解 myBatis 这段应该了 user.user_name like #{userName}, 按此救命我们将现在有信息解析为此就相当容易了

stringBuffer

.append(" ")

.append(tableEntity.getNickName()) // 表的nick name

.append(".")

.append(tableEntity.getTableColumns().get(tableEntity.getEntityColumns().indexOf(fieldName))) //通过field名称找到数据表中的字段

.append(" ")

.append("like ")//opreaction 操作

.append("#{parameter.")

.append(key) // 不重复的key 如 userName

.append("}");

parameter.put(key, value); //将对应的key 和 value 存储起来,用于调xml时候作为参数传递过去

//简易的思路就完成了

现在已经准备好解析完成的sqlSegment了,那么我们要把他放在myBatis的Xml里,我们定义个MulSelectMapper.java && MulSelectMapper.xml

//MulSelectMapper.java

public interface MulSelectMapper {

public List> multiSelect(MulSelect param);

//分页统计总数

public Integer countMulSelect(MulSelect param);

}

//MulSelectMapper.xml

select distinct ${selectColumns} from ${masterTable}

left join ${item}

${sqlSegment}

group by ${groupBy}

order by ${orderBy}

limit #{start}, #{end}

现在就差一个通用的service 来调用了 MultipleService.java

public class MultipleService {

MultipleResult multipleSelect(MulSelect param);

}

//调用通用查询将

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Spring MVC是基于Spring框架的一种Web框架,用于开发Java Web应用程序。而Spring是一个轻量级的IoC(Inverse of Control)和AOP(Aspect-Oriented Programming)容器,通过IOC容器,可以管理各种Java Bean的生命周期和依赖关系,而通过AOP可以实现一些跨越多个模块或对象的通用功能。 MyBatis是一个持久层框架,它可以将数据库操作抽象为Java接口的方法,通过配置文件将这些方法映射到相应的SQL语句,实现轻量级的数据库访问。 SpringMVC、Spring和MyBatis可以结合使用来开发一个完整的Java Web项目。 在一个典型的SpringMVC、Spring和MyBatis项目中,通常会有以下几个主要组件: 1. 控制器(Controller):负责接收用户的请求,处理业务逻辑,并返回相应的结果。SpringMVC提供了很多注解和接口,可以很方便地定义和处理请求。 2. 服务(Service):负责处理具体的业务逻辑。通常一个服务类会对应一个或多个DAO(Data Access Object),通过DAO对象访问数据库,获取或修改数据。 3. DAO(Data Access Object):负责封装与数据库交互的细节。通过使用MyBatis的映射文件,将Java接口的方法映射到相应的SQL语句。 4. 数据库:使用关系型数据库(如MySQL、Oracle等)存储持久化数据。 在项目中,通过配置文件和注解,将这些组件关联起来。Spring框架负责管理各个组件的生命周期和依赖关系,MyBatis提供数据访问功能,SpringMVC负责接收用户请求并将结果返回给用户。 通过SpringMVC、Spring和MyBatis的结合,可以实现一个完整的Java Web项目,使开发者能够更加方便、高效地进行开发,并且能够更好地实现各个组件之间的解耦和复用。 ### 回答2: springmvc spring mybatis是一种常见的Java Web开发框架组合,被广泛应用于企业级的Web应用程序开发中。下面以一个简单的项目实例来介绍其基本用法。 假设我们要开发一个简单的学生信息管理系统,使用springmvc来搭建前端控制器,spring来进行依赖注入和事务管理,mybatis作为持久层框架与数据库交互。 首先,我们需要进行项目的初始化配置。在Spring配置文件中,配置相关的bean以及包扫描路径,使得框架能够自动扫描并管理相应的组件。 接下来,我们创建相应的实体类,例如学生类,可以定义属性如姓名、年龄等,并使用注解进行实体类与数据库的映射。同时,我们可以创建DAO接口和Mapper映射文件,用于扩展mybatis的CURD操作。 然后,我们在Controller中编写处理请求的方法,通过注解标识URL映射关系、请求类型,使用Service层的方法进行业务处理,并将结果传递给视图解析器进行渲染。 在Service层,我们可以编写相应的逻辑代码,例如添加、删除、修改学生信息等。同时,我们可以利用@Autowired注解将DAO层的方法注入到Service中,从而将数据库操作与业务逻辑进行分离。 最后,我们可以在视图层创建相应的页面,例如添加、删除、修改学生信息的页面。利用EL达式和JSTL标签库等,实现数据的展示和交互。 总的来说,springmvc spring mybatis的项目实例中,我们通过配置框架的相关组件,编写实体类、映射文件以及相应的控制器、服务层和视图层代码,从而实现了一个简单的学生信息管理系统。通过这个实例,我们可以更好地理解和掌握springmvc spring mybatis的基本用法和项目架构。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值