SpringBoot中MybatisPlus条件构造器

1.AbstractWrapper

说明:QueryWrapper(LambdaQueryWrapper) 和 UpdateWrapper(LambdaUpdateWrapper) 的父类。用于生成 sql 的 where 条件, entity 属性也用于生成 sql 的 where 条件

1.1 allEq (全部eq或个别 isNull)

allEq(Map<R,V> params)
allEq(Map<R,V> params,boolean null2IsNull)
allEq(boolean condition,Map<R,V> params,boolean null2IsNull)

个别参数说明:

            params : key为数据库字段名,value为字段值

            null2IsNull : 为true则在map的value为null时调用 isNull 方法,为false时则忽略value为null的

例1: allEq({id:1,name:"老王",age:null})--->id = 1 and name = '老王' and age is null

例2: allEq({id:1,name:"老王",age:null}, false)--->id = 1 and name = '老王'

 

1.2 eq  全部eq 或个别isNull)

eq(R column, Object val)
eq(boolean condition, R column, Object val)

 例: eq("name", "老王")--->name = '老王'

1.3 ne(不等于 <>)

ne(R column, Object val)
ne(boolean condition, R column, Object val)

例: ne("name", "老王")--->name <> '老王'

1.4 gt(大于 >)

gt(R column, Object val)
gt(boolean condition, R column, Object val)

例: gt("age", 18)--->age > 18

1.5 ge(大于等于 >=)

ge(R column, Object val)
ge(boolean condition, R column, Object val)

例: ge("age", 18)--->age >= 18

1.6 lt(小于 <)

lt(R column, Object val)
lt(boolean condition, R column, Object val)

例: lt("age", 18)--->age < 18

1.7 le(小于等于 <=)

le(R column, Object val)
le(boolean condition, R column, Object val)

例: le("age", 18)--->age <= 18

1.8 between(BETWEEN 值1 AND 值2)

between(R column, Object val1, Object val2)
between(boolean condition, R column, Object val1, Object val2)

例: between("age", 18, 30)--->age between 18 and 30

1.9 notBetween(NOT BETWEEN 值1 AND 值2)

notBetween(R column, Object val1, Object val2)
notBetween(boolean condition, R column, Object val1, Object val2)

例: notBetween("age", 18, 30)--->age not between 18 and 30

1.10 like(LIKE '%值%')

like(R column, Object val)
like(boolean condition, R column, Object val)

例: like("name", "王")--->name like '%王%'

1.11 notLike(NOT LIKE '%值%')

notLike(R column, Object val)
notLike(boolean condition, R column, Object val)

例: notLike("name", "王")--->name not like '%王%'

1.12 likeLeft(LIKE '%值')

likeLeft(R column, Object val)
likeLeft(boolean condition, R column, Object val)

例: likeLeft("name", "王")--->name like '%王'

1.13 likeRight(LIKE '值%')


likeRight(R column, Object val)
likeRight(boolean condition, R column, Object val)

例: likeRight("name", "王")--->name like '王%'

1.14 isNull(字段 IS NULL)

isNull(R column)
isNull(boolean condition, R column)

例: isNull("name")--->name is null

1.15 isNotNull(字段 IS NOT NULL)

isNotNull(R column)
isNotNull(boolean condition, R column)

例: isNotNull("name")--->name is not null

1.16 in(字段 IN (字段 IN (v0, v1, ...)),参数可以是Collection的实现类,或者数组

in(R column, Collection<?> value)
in(boolean condition, R column, Collection<?> value)
in(R column, Object... values)
in(boolean condition, R column, Object... values)

例: in("age",{1,2,3})--->age in (1,2,3)
例: in("age", 1, 2, 3)--->age in (1,2,3)

1.17 notIn(NOT IN (v0, v1, ...)),参数可以是Collection的实现类,或者数组

notIn(R column, Collection<?> value)
notIn(boolean condition, R column, Collection<?> value)
notIn(R column, Object... values)
notIn(boolean condition, R column, Object... values)

例: notIn("age",{1,2,3})--->age not in (1,2,3)
例: notIn("age", 1, 2, 3)--->age not in (1,2,3)

1.18 inSql(字段 IN ( sql语句 ))

inSql(R column, String inValue)
inSql(boolean condition, R column, String inValue)

例: inSql("age", "1,2,3,4,5,6")--->age in (1,2,3,4,5,6)
例: inSql("id", "select id from table where id < 3")--->id in (select id from table where id < 3)

1.19 notInSql(字段 NOT IN ( sql语句 ))

notInSql(R column, String inValue)
notInSql(boolean condition, R column, String inValue)

例: notInSql("age", "1,2,3,4,5,6")--->age not in (1,2,3,4,5,6)
例: notInSql("id", "select id from table where id < 3")--->age not in (select id from table where id < 3)

1.20 groupBy (分组:GROUP BY 字段, ...)

orderByAsc(R... columns)
orderByAsc(boolean condition, R... columns)

例: groupBy("id", "name")--->group by id,name

1.21 orderByAsc (排序:ORDER BY 字段, ... ASC)

orderByAsc(R... columns)
orderByAsc(boolean condition, R... columns)

例: orderByAsc("id", "name")--->order by id ASC,name ASC

1.22 orderByDesc(排序:ORDER BY 字段, ... DESC)

orderByDesc(R... columns)
orderByDesc(boolean condition, R... columns)

例: orderByDesc("id", "name")--->order by id DESC,name DESC

1.23 orderBy(排序:ORDER BY 字段, ...)

orderBy(boolean condition, boolean isAsc, R... columns)

例: orderBy(true, true, "id", "name")--->order by id ASC,name ASC

1.24 having(HAVING ( sql语句 ))

having(String sqlHaving, Object... params)
having(boolean condition, String sqlHaving, Object... params)

例: having("sum(age) > 10")--->having sum(age) > 10
例: having("sum(age) > {0}", 11)--->having sum(age) > 11

1.25 or(拼接 OR)

or()
or(boolean condition)
or(Consumer<Param> consumer)
or(boolean condition, Consumer<Param> consumer)

注意事项: 主动调用or表示紧接着下一个方法不是用and连接!(不调用or则默认为使用and连接)
例: eq("id",1).or().eq("name","老王")--->id = 1 or name = '老王'
例: or(i -> i.eq("name", "李白").ne("status", "活着"))--->or (name = '李白' and status <> '活着')

1.26 and(AND 嵌套)

and(Consumer<Param> consumer)
and(boolean condition, Consumer<Param> consumer)

例: and(i -> i.eq("name", "李白").ne("status", "活着"))--->and (name = '李白' and status <> '活着')

1.27 nested(正常嵌套 不带 AND 或者 OR)

nested(Consumer<Param> consumer)
nested(boolean condition, Consumer<Param> consumer)

例: nested(i -> i.eq("name", "张飞").ne("status", "活着"))--->(name = '张飞' and status <> '活着')

1.28 apply(拼接 sql)

apply(String applySql, Object... params)
apply(boolean condition, String applySql, Object... params)

注意事项:该方法可用于数据库函数 动态入参的params对应前面applySql内部的{index}部分.这样是不会有sql注入风险的,反之会有!
例: apply("id = 1")--->id = 1
例: apply("date_format(dateColumn,'%Y-%m-%d') = '2008-08-08'")--->date_format(dateColumn,'%Y-%m-%d') = '2008-08-08'")
例: apply("date_format(dateColumn,'%Y-%m-%d') = {0}", "2008-08-08")--->date_format(dateColumn,'%Y-%m-%d') = '2008-08-08'")

1.29 last(无视优化规则直接拼接到 sql 的最后)

last(String lastSql)
last(boolean condition, String lastSql)

注意事项:只能调用一次,多次调用以最后一次为准 有sql注入的风险,请谨慎使用
例: last("limit 1")

1.30 exists(拼接 EXISTS ( sql语句 ))

exists(String existsSql)
exists(boolean condition, String existsSql)

例: exists("select id from table where age = 1")--->exists (select id from table where age = 1)

1.31 notExists(拼接 NOT EXISTS ( sql语句 ))

notExists(String notExistsSql)
notExists(boolean condition, String notExistsSql)

例: notExists("select id from table where age = 1")--->not exists (select id from table where age = 1)

 

2. QueryWrapper

说明:
  继承自 AbstractWrapper ,自身的内部属性 entity 也用于生成 where 条件
  及 LambdaQueryWrapper, 可以通过 new QueryWrapper().lambda() 方法获取

2.1 select(设置查询字段)

select(String... sqlSelect)
select(Predicate<TableFieldInfo> predicate)
select(Class<T> entityClass, Predicate<TableFieldInfo> predicate)

说明:
以上方分法为两类.
第二类方法为:过滤查询字段(主键除外),入参不包含 class 的调用前需要wrapper内的entity属性有值! 这两类方法重复调用以最后一次为准

例: select("id", "name", "age")
例: select(i -> i.getP

3. UpdateWrapper

说明:
  继承自 AbstractWrapper ,自身的内部属性 entity 也用于生成 where 条件
  及 LambdaUpdateWrapper, 可以通过 new UpdateWrapper().lambda() 方法获取!

3.1 set(SQL SET 字段)

set(String column, Object val)
set(boolean condition, String column, Object val)

例: set("name", "老李头")
例: set("name", "")--->数据库字段值变为空字符串
例: set("name", null)--->数据库字段值变为null

3.2 setSql(设置 SET 部分 SQL)

setSql(String sql)

例: setSql("name = '老李头'")

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 人力资源管理系统(Human Resource Management System,简称HRMS)是一种基于Spring BootMybatis Plus的人力资源管理软件。它是为了帮助企业更好地管理和优化其人力资源而设计的。 HRMS具有以下几个主要功能: 1. 员工管理:HRMS可以实现对员工的信息进行管理,包括员工基本信息、岗位信息、部门信息等。通过系统,管理者可以对员工进行增删改查等操作,方便快捷地管理员工数据。 2. 薪资管理:HRMS可以自动计算员工的薪资并生成工资单,根据不同的岗位、等级和绩效,计算不同员工的薪资,并提供薪资发放的记录和统计。 3. 考勤管理:HRMS可以对员工的考勤情况进行记录和管理,包括请假、出差、加班等。通过系统,可以查看员工的考勤记录和统计数据,方便管理者进行调度和工作安排。 4. 培训管理:HRMS可以记录员工的培训信息和培训成果,包括培训计划、培训材料和培训效果评估。通过系统,可以为员工制定培训计划,统计培训情况,并为企业提供人员培训情况的数据支持。 5. 绩效管理:HRMS可以对员工的绩效进行评估和管理,包括设定目标、评估表和绩效考核结果。通过系统,可以定期对员工的绩效进行评估和考核,并提供绩效评估的数据和报表。 总的来说,人力资源管理系统Spring Boot Mybatis Plus可以帮助企业更好地管理和优化其人力资源,提高企业的运营效率和管理水平。通过自动化和集化管理,可以减少人力成本和提高工作效率,为企业的发展提供有力的支持。 ### 回答2: 人力资源管理系统springboot mybatisplus 是一种基于springbootmybatisplus框架开发的人力资源管理系统。该系统主要用于管理企业的人力资源信息,包括员工的基本信息、薪资福利、绩效考核、培训发展等方面。 springboot是一种基于spring框架的开发工具,它简化了项目的配置和部署,并提供了丰富的开发功能和插件,使得开发人员能够更加高效地开发和维护项目。 mybatisplus是mybatis的增强工具,它在mybatis的基础上提供了更多的便利功能,比如自动生成代码、分页查询、多表关联等。使用mybatisplus可以简化数据库操作,提高开发效率。 人力资源管理系统的开发过程,可以使用springboot作为项目的基础框架,通过其内嵌的Tomcat容器和自动配置功能,简化了项目的搭建和部署。同时,可以借助springboot的starter模块集成mybatisplus,实现与数据库的连接和操作。 在系统的实现过程,可以通过使用mybatisplus的代码生成功能,根据数据库表结构自动生成DAO层的代码。在代码编写过程,可以使用mybatisplus提供的查询构造器和分页插件,实现复杂查询和分页查询的功能。 系统的业务逻辑可以根据实际需求进行编写,比如员工信息的增删改查、薪资福利的计算和调整、绩效考核的评定等。通过使用springbootmybatisplus的组合,可以快速开发出一个功能完善、性能优良的人力资源管理系统。 综上所述,人力资源管理系统springboot mybatisplus是一种基于springbootmybatisplus框架开发的系统,它具有高效、简单、灵活等特点,能够满足企业对于人力资源管理的需求。 ### 回答3: 人力资源管理系统是一种通过技术手段管理企业的人力资源,实现人力资源的信息化、系统化和自动化的管理方式。而Spring Boot是一种用于构建独立的、可执行的、生产级别的Spring应用程序的框架。MyBatis Plus则是一款为了简化MyBatis的使用而开发的增强工具包。 结合这三个关键词,可以推测出人力资源管理系统Spring Boot MyBatis Plus应用的情境。正常情况下,人力资源管理系统可以利用Spring Boot作为后端框架,MyBatis Plus作为持久层框架,来实现对人力资源数据的存储和处理。 在这个系统Spring Boot可以提供丰富的功能和特性,如快速搭建、内嵌Tomcat服务器、自动化配置等。它也可以与其他Spring生态系统的组件(如Spring Data、Spring Security)进行无缝集成,从而加速开发过程。 MyBatis Plus则可以提供更便捷的CRUD操作,将原始的MyBatis进行了增强,简化了常用的SQL操作,减少了手动编写SQL的工作量。它提供了诸如分页、条件构造器、通用的增删改查方法等功能,使开发者能够更加高效地操作数据库。 综上所述,人力资源管理系统Spring Boot MyBatis Plus应用结合了Spring BootMyBatis Plus的优势,使得开发者能够更加快速地搭建人力资源管理系统,并且能够更加方便地操作和管理人力资源数据。这样的应用架构能够提高开发效率,降低开发成本,同时也提升了系统的稳定性和可维护性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

潘涛智码工坊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值