【java框架】MyBatis-Plus(1)--MyBatis-Plus快速上手开发及核心功能体验(2)

.插件扩展
3.1.乐观锁插件
当我们在开发中,有时需要判断,当我们更新一条数据库记录时,希望这条记录没有被别人更新,这个时候就可以使用乐观锁插件。

乐观锁的实现方式:

取出记录时,获取当前的version;
更新时,带上这个version;
执行更新时,set version = new version where version = oldversion;
如果version不对,就更新失败
具体实现步骤如下:

①数据库新增乐观锁字段version,设置默认值为1:

②在实体类User中新增version字段:

@Version //乐观锁Version注解
private Integer version;

③注册乐观锁主键:

复制代码
//开启事务
@EnableTransactionManagement
@Configuration //声明此类是配置类
public class MyBatisplusConfig {
// 注册乐观锁插件
@Bean
public OptimisticLockerInterceptor optimisticLockerInterceptor() {
return new OptimisticLockerInterceptor();
}
}
复制代码

④测试单线程多线程情况乐观锁是否执行更新update成功:

复制代码
// 测试乐观锁单线程执行成功
@Test
public void testOptimisticLocker(){
// 1、查询用户信息
User user = userMapper.selectById(1L);
// 2、修改用户信息
user.setName(“fengye”);
user.setEmail(“241337663@qq.com”);
// 3、执行更新操作
userMapper.updateById(user);
}

// 测试乐观锁失败!多线程下
@Test
public void testOptimisticLocker2(){
// 线程 1
User user = userMapper.selectById(1L);
user.setName(“fengye111”);
user.setEmail(“241337663@qq.com”);
// 模拟另外一个线程执行了插队操作
User user2 = userMapper.selectById(1L);
user2.setName(“fengye222”);
user2.setEmail(“241337663@qq.com”);
userMapper.updateById(user2);
userMapper.updateById(user); // 如果没有乐观锁就会覆盖插队线程的值!
}
复制代码

3.2.性能分析插件
MyBatis-Plus提供的性能分析插件可以作为性能分析拦截器,用于输出每条SQL语句及其执行时间。可以在开发测试时定量分析慢查询的SQL语句,用于后期优化分析。

具体使用步骤:

①在MyBatis-PlusConfig类中配置SQL性能分析插件:

复制代码
/**

  • SQL执行效率插件
    */
    @Bean
    @Profile({“dev”,“test”})// 设置 dev test 环境开启,保证我们的效率
    public PerformanceInterceptor performanceInterceptor() {
    PerformanceInterceptor performanceInterceptor = new PerformanceInterceptor();
    performanceInterceptor.setMaxTime(100); // ms设置sql执行的最大时间为100ms,如果超过了则不执行
    performanceInterceptor.setFormat(true); // 是否格式化代码
    return performanceInterceptor;
    }
    复制代码

②配置插件运行环境为dev:

#设置开发环境为dev
spring.profiles.active=dev

③执行测试,可以看到sql已经format及实际执行sql语句的消耗时间:

复制代码
@Test
public void testPerformance(){
// 查询全部用户
List users = userMapper.selectList(null);
users.forEach(System.out::println);
}
复制代码

3.3.代码生成器
AutoGenerator 是 MyBatis-Plus 的代码生成器,通过 AutoGenerator 可以快速生成 Entity、Mapper、Mapper XML、Service、Controller 等各个模块的代码,极大的提升了开发效率。

具体使用步骤如下:

①使用代码生成器(Mybatis-Plus3.1.1版本以下)需要添加velocity模板、Swagger配置:

复制代码

org.apache.velocity velocity-engine-core 2.3 com.spring4all spring-boot-starter-swagger 1.5.1.RELEASE provided 复制代码

②编写自动生成器类:

复制代码
public class AutoGeneratorUtil {
public static void main(String[] args) {
AutoGenerator mpg = new AutoGenerator();
// 策略配置
// 1、全局配置
GlobalConfig gc = new GlobalConfig();
String projectPath = System.getProperty(“user.dir”);
gc.setActiveRecord(true); //是否开启AR模式
gc.setAuthor(“fengye”);
gc.setOutputDir(projectPath+"/src/main/java");
gc.setOpen(false);
gc.setFileOverride(false); // 是否覆盖
gc.setServiceName("%sService"); // 设置生成的services接口的名字的首字母是否为I
//gc.setIdType(IdType.ID_WORKER);
//gc.setDateType(DateType.ONLY_DATE);
gc.setSwagger2(true);
mpg.setGlobalConfig(gc);
//2、设置数据源
DataSourceConfig dsc = new DataSourceConfig();
dsc.setDriverName(“com.mysql.cj.jdbc.Driver”);
dsc.setUrl(“jdbc:mysql://localhost:3306/mybatisplus_0312?useSSL=false&useUnicode=true&characterEncoding=utf-8&serverTimezone=GMT%2B8”);
dsc.setUsername(“root”);
dsc.setPassword(“admin”);
dsc.setDbType(DbType.MYSQL);
mpg.setDataSource(dsc);
//3、包的配置
PackageConfig pc = new PackageConfig();
pc.setModuleName(“test”);
pc.setParent(“com.fengye”);
pc.setEntity(“entity”);
pc.setMapper(“mapper”);
//设置xml文件与mapper目录同级
pc.setXml(“mapper”);
pc.setService(“service”);
pc.setController(“controller”);
mpg.setPackageInfo(pc);
//4、策略配置
StrategyConfig strategy = new StrategyConfig();
//设置要映射的表名,支持多张表以逗号隔开
strategy.setInclude(“user”, “t_dept”, “t_employee”);
strategy.setNaming(NamingStrategy.underline_to_camel);
strategy.setColumnNaming(NamingStrategy.underline_to_camel);
strategy.setEntityLombokModel(true); //使用lombok注解
strategy.setRestControllerStyle(true); //Restful风格
strategy.setLogicDeleteFieldName(“deleted”); //逻辑删除名称
//5、自动填充配置
TableFill gmtCreate = new TableFill(“gmt_create”, FieldFill.INSERT);
TableFill gmtModified = new TableFill(“gmt_modified”, FieldFill.INSERT_UPDATE);
ArrayList tableFills = new ArrayList<>();
tableFills.add(gmtCreate);
tableFills.add(gmtModified);
strategy.setTableFillList(tableFills);
//6、乐观锁
strategy.setVersionFieldName(“version”);strategy.setRestControllerStyle(true);
strategy.setControllerMappingHyphenStyle(true); //设置映射地址支持下划线 localhost:8080/hello_id_2
mpg.setStrategy(strategy);
mpg.execute();
}
}
USB Microphone https://www.soft-voice.com/
Wooden Speakers https://www.zeshuiplatform.com/
亚马逊测评 www.yisuping.cn
深圳网站建设www.sz886.com

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值