著名的wordpress主题公园,百度竞价推广账户优化,网站如何屏蔽ip段,wordpress 严重 漏洞文章目录 条件构造器补充知识TypeHandlerWrappers示例#xff1a; 线程安全性示例#xff1a; 使用 Wrapper 自定义 SQL示例#xff1a;使用方法 使用注解查询使用XML配置查询链式调用与Lambda式调用 条件构造器补充知识
TypeHandler
在 wrapper 中使用 typeHandler 需要特… 文章目录 条件构造器补充知识TypeHandlerWrappers示例 线程安全性示例 使用 Wrapper 自定义 SQL示例使用方法 使用注解查询使用XML配置查询链式调用与Lambda式调用 条件构造器补充知识
TypeHandler
在 wrapper 中使用 typeHandler 需要特殊处理利用 formatSqlMaybeWithParam 方法
// 查询
queryWrapper.apply(type{0,typeHandler MyTypeHandler.class.getCanonicalName() }, 待处理字符串);// 更新
updateWrapper.setSql(type{0,javaTypestring,jdbcTypeVARCHAR,typeHandlerxxx.xxx.MyTypeHandler}, 待处理字符串);使用提示: 通过使用 MyBatis-Plus 的 Wrapper 条件构造器开发者可以更加高效地构建复杂的数据库查询条件同时保持代码的简洁性和安全性。以下是一些注意事项与推荐做法 在使用 Wrapper 时尽量使用 Lambda 表达式来避免硬编码字段名这样可以提高代码的可读性和可维护性。 Wrapper 支持链式调用可以组合多个条件如 and、or 等逻辑操作符。 在更新操作中使用 UpdateWrapper 或 LambdaUpdateWrapper 时可以省略实体对象直接在 Wrapper 中设置更新字段。 注意 Wrapper 的线程安全性通常在每次使用时创建新的 Wrapper 实例。 在使用 MyBatis-Plus 的 Wrapper 时应避免将前端动态参数直接拼接到 SQL 片段中以防止 SQL 注入攻击。MyBatis-Plus 提供了安全的参数绑定方式如使用 eq、apply 等方法它们会自动处理参数绑定避免 SQL 注入风险。
Wrappers
MyBatis-Plus 提供了 Wrappers 类它是一个静态工厂类用于快速创建 QueryWrapper、UpdateWrapper、LambdaQueryWrapper 和 LambdaUpdateWrapper 的实例。使用 Wrappers 可以减少代码量提高开发效率。
示例
// 创建 QueryWrapper
QueryWrapperUser queryWrapper Wrappers.query();
queryWrapper.eq(name, 张三);// 创建 LambdaQueryWrapper
LambdaQueryWrapperUser lambdaQueryWrapper Wrappers.lambdaQuery();
lambdaQueryWrapper.eq(User::getName, 张三);// 创建 UpdateWrapper
UpdateWrapperUser updateWrapper Wrappers.update();
updateWrapper.set(name, 李四);// 创建 LambdaUpdateWrapper
LambdaUpdateWrapperUser lambdaUpdateWrapper Wrappers.lambdaUpdate();
lambdaUpdateWrapper.set(User::getName, 李四);线程安全性
Wrapper 实例不是线程安全的因此建议在每次使用时创建新的 Wrapper 实例。这样可以避免多线程环境下的数据竞争和潜在的错误。
示例
// 在每个方法或请求中创建新的 Wrapper 实例
public ListUser getUsersByName(String name) {QueryWrapperUser queryWrapper Wrappers.query();queryWrapper.eq(name, name);return userMapper.selectList(queryWrapper);
}通过遵循这些最佳实践开发者可以更加安全、高效地使用 MyBatis-Plus 的 Wrapper 条件构造器构建出既安全又易于维护的数据库操作代码。
使用 Wrapper 自定义 SQL
MyBatis-Plus 提供了强大的 Wrapper 条件构造器允许开发者自定义 SQL 语句以满足更复杂的数据库查询需求。为了使用这一功能请确保你的 mybatis-plus 版本不低于 3.0.7。 注意事项
版本要求确保你的项目中使用的 mybatis-plus 版本至少为 3.0.7以支持自定义 SQL 功能。参数命名在自定义 SQL 时传递 Wrapper 对象作为参数时参数名必须为 ew或者使用注解 Param(Constants.WRAPPER) 明确指定参数为 Wrapper 对象。使用 ${ew.customSqlSegment}在 SQL 语句中使用 ${ew.customSqlSegment} 来引用 Wrapper 对象生成的 SQL 片段。不支持基于 entity 的 where 语句自定义 SQL 时Wrapper 对象不会基于实体类自动生成 where 子句你需要手动编写完整的 SQL 语句。
示例
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.toolkit.Constants;
import org.apache.ibatis.annotations.Param;public interface UserMapper extends BaseMapperUser {Select(SELECT * FROM user ${ew.customSqlSegment})ListUser selectByCustomSql(Param(Constants.WRAPPER) WrapperUser wrapper);
}在上述示例中我们定义了一个 selectByCustomSql 方法它使用了一个自定义的 SQL 语句并通过 ${ew.customSqlSegment} 引入了 Wrapper 对象生成的 SQL 片段。
使用方法
要使用自定义 SQL只需调用上述方法并传入一个 Wrapper 对象
QueryWrapperUser queryWrapper new QueryWrapper();
queryWrapper.eq(name, 张三);ListUser userList userMapper.selectByCustomSql(queryWrapper);在这个例子中selectByCustomSql 方法将执行一个带有 where 条件的查询该条件由传入的 queryWrapper 对象生成。
通过这种方式你可以灵活地结合 MyBatis-Plus 的 Wrapper 功能和自定义 SQL以满足各种复杂的数据库操作需求。
使用注解查询
Select(select * from mysql_data ${ew.customSqlSegment})
ListMysqlData getAll(Param(Constants.WRAPPER) Wrapper wrapper);使用XML配置查询
ListMysqlData getAll(Wrapper ew);select idgetAll resultTypeMysqlDataSELECT * FROM mysql_data ${ew.customSqlSegment}
/select链式调用与Lambda式调用
MyBatis-Plus提供了两种风格的链式调用普通链式调用和Lambda式链式调用。需要注意的是Lambda式链式调用不支持Kotlin。
// 普通链式调用
UpdateChainWrapperT update();
// Lambda式链式调用不支持Kotlin
LambdaUpdateChainWrapperT lambdaUpdate();// 等价示例
query().eq(id, value).one();
lambdaQuery().eq(Entity::getId, value).one();// 等价示例
update().eq(id, value).remove();
lambdaUpdate().eq(Entity::getId, value).remove();通过遵循这些最佳实践我们可以确保Kotlin中的持久化对象定义既清晰又易于维护同时充分利用MyBatis-Plus提供的功能。