当前位置: 首页 > news >正文

运营商做网站wordpress文章无法使用

运营商做网站,wordpress文章无法使用,手机网站cms 下载,网站上的代码网页怎么做的了解MyBatis-Plus 什么是MyBatis-Plus? mybatisPlus在mybatis的基础上继续针对CRUD操作进行优化,在原有的基础上提供了公共的接口BaseMapper,我们在创建接口Mapper时只需要继承这个接口即可调用MyBatisPlus已经提供好的方法,sql…

了解MyBatis-Plus

什么是MyBatis-Plus?

mybatisPlus在mybatis的基础上继续针对CRUD操作进行优化,在原有的基础上提供了公共的接口BaseMapper,我们在创建接口Mapper时只需要继承这个接口即可调用MyBatisPlus已经提供好的方法,sql和方法都是已经被MyBatisPlus内置的

并且MyBatisPlus在MyBatis的基础上又扩展了更加强大的功能,比如内置了分页插件、代码自动生成等等极大的优化了开发效率

体验MyBatisPlus

1、创建SpringBoot项目

2、编写实体类以及其对应接口并继承BaseMapper,将编写好的实体类填充至泛型,接口中不需要声明任何方法。只需要按照正常的开发顺序添加@Repository或者@Mapper保证将其托管给Spring容器即可

@Repository
public interface UserMapper extends BaseMapper<User> { }

3、在主程序上方开启接口扫描,保证我们定义好的接口可以被识别生效

@MapperScan("com.yuqu.mapper")
@SpringBootApplication

4、开始测试

@Test
public void test01(){List<User> list = userMapper.selectList(null);list.forEach(System.out::println);
}

主键生成策略

我们先来执行一次插入操作,只指定除ID以外的其他字段

int i = userMapper.insert(new User("张三", 25, "yuqu1028@163.com"));
// 默认添加id:1630488694524837889
System.out.println("影响行数"+i);

最终添加成功,但是ID是由mybatisPlus帮助生成的,但是我们可以通过在实体类的ID属性上添加@TableID注解来指定id生成的策略。

@TableId()
private Long id;// 将@TableId注解放在id字段上

可以为其设置参数@TableId(type = IdType.AUTO)表示自增,但是要保证数据库也设置了该字段为自增字段
以及ASSIGN_ID表示当插入对象ID为空时,才会自动填充。默认再用雪花算法实现
ASSIGN_UUID 表示为其分配UUID:UUID.replace(“-”,“”)

INPUT表示由手动插入ID,NONE表示表中没有主键

自动填充

第一种方式是可以在数据库层面进行操作,设置创建时间和更新时间。

第二种就是mybatis-plus提供的注解,在需要更新和自动填充的字段上进行修饰

// 设置创建实际按自动填充
@TableField(fill = FieldFill.INSERT)
private Date createTime;
// 设置更新实际按填充并且自动更新
@TableField(fill = FieldFill.INSERT_UPDATE)
private Date updateTime;

标记上注解之后去自定义处理器,自定义一个类实现mybatisPlus提供的一个数据接口MetaObjectHandler,并且重写两个方法insertFill和updateFill

@Slf4j
@Component
public class MyHandler implements MetaObjectHandler {@Overridepublic void insertFill(MetaObject metaObject) {log.info("start insert fill....");this.setFieldValByName("createTime",new Date(),metaObject);this.setFieldValByName("updateTime",new Date(),metaObject);}@Overridepublic void updateFill(MetaObject metaObject) {log.info("start update fill....");this.setFieldValByName("updateTime",new Date(),metaObject);}
}

乐观锁机制

给数据库添加version字段,在访问对某一条数据进行操作时会先获取到它的version。获取到之后进行需要进行的操作然后设置version+1,在刷新数据的时候进行判断如果version==1那就说明这段时间没有别的线程并发操作了该数据,即数据是安全的,就可以提交数据

依然是将@Version注解修饰在对应属性上,表示这是一个乐观锁

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

配置mybatisPlus乐观锁插件

// 配置version乐观锁插件  拦截器
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());return interceptor;
}

分页查询

mybatisPlus内置了分页插件,与乐观锁一样需要在mybatisPlus配置类中配置并注入bean即可使用

// 分页插件
@Bean
public PaginationInnerInterceptor paginationInnerInterceptor(){return new PaginationInnerInterceptor();
}

测试分页

@Test
public void test05(){// param1:页码 param2:页面数据条数Page<User> page = new Page<>(1,3);// 查询总数System.out.println(page.getTotal());userMapper.selectPage(page,null);// 根据page查询指定数目数据page.getRecords().forEach(System.out::println);
}

逻辑删除

表示并不是真正的将数据从数据库中删除,而是让其失效。比如手机中删除照片的最近删除,要删除这些已经“删除”的数据再进行一次深度删除即可,使用时只需要在数据库表中定义一个字段,并在实体类对应字段上用注解标注字段即可

@TableLogic // 逻辑删除注解
private Integer deleted;

测试删除:user.deleteById(6);最终执行成功并不是将该数据真正删除,而是将修改该数据的deleted字段为1,该字段为0表示未删除。也可以在springBoot的yaml配置文件中进行修改,自定义的值将会覆盖默认值

mybatis-plus:global-config:db-config:# 逻辑删除字段名logic-delete-field: deleted# 未删除标识logic-not-delete-value: 0# 已删除标识logic-delete-value: 1

执行SQL分析打印

可以格式化执行的sql,更加直观的看到sql语句。以及打印执行用时,常用于测试找到慢查询。但是缺点mybatis官方也指出了: 该插件有性能损耗,不建议生产环境使用

导入p6spy打印SQL依赖

<!--      执行sql分析打印  -->
<!-- https://mvnrepository.com/artifact/p6spy/p6spy -->
<dependency><groupId>p6spy</groupId><artifactId>p6spy</artifactId><version>3.9.1</version>
</dependency>

在resource目录下创建spy.properties配置文件然后就可以直接使用

#3.2.1以上使用
modulelist=com.baomidou.mybatisplus.extension.p6spy.MybatisPlusLogFactory,com.p6spy.engine.outage.P6OutageFactory
#3.2.1以下使用或者不配置
#modulelist=com.p6spy.engine.logging.P6LogFactory,com.p6spy.engine.outage.P6OutageFactory
# 自定义日志打印
logMessageFormat=com.baomidou.mybatisplus.extension.p6spy.P6SpyLogger
#日志输出到控制台
appender=com.baomidou.mybatisplus.extension.p6spy.StdoutLogger
# 使用日志系统记录 sql
#appender=com.p6spy.engine.spy.appender.Slf4JLogger
# 设置 p6spy driver 代理
deregisterdrivers=true
# 取消JDBC URL前缀
useprefix=true
# 配置记录 Log 例外,可去掉的结果集有error,info,batch,debug,statement,commit,rollback,result,resultset.
excludecategories=info,debug,result,commit,resultset
# 日期格式
dateformat=yyyy-MM-dd HH:mm:ss
# 实际驱动可多个
#driverlist=org.h2.Driver
# 是否开启慢SQL记录
outagedetection=true
# 慢SQL记录标准 2 秒
outagedetectioninterval=2

条件构造器Wrapper

建议参考MyBatis-Plus官网:
https://baomidou.com/pages/10c804/

http://www.yayakq.cn/news/762588/

相关文章:

  • 广州祥云平台网站建设网站制作过程简介
  • 网页设计与网站建设案例教程msn wordpress
  • 手机微网站模板下载手机网站主机
  • wordpress高级破解主题什么是优化产业结构
  • 平台和自建网站服务提供者查看网站被恶意镜像
  • 怎么查看服务器上的网站生活分类信息网站大全
  • 服装网站设计策划同城分类网站建设
  • 网站排名优化培训哪家好快速网站
  • 以网站建设为开题报告自己接私单网站开发
  • 网站的广告语应该怎么做vs做网站怎样添加图片
  • 吉安公司做网站网站建设资金投入分析
  • 网站设计的提案做自己的程序设计在线测评网站
  • 高校网站模板龙岩网上办事大厅官网
  • 利津网站建设网站开发需要多久
  • 万网建网站做网站先建立模型
  • 辛集seo网站优化电话做外贸如何分析客户网站
  • 北京模板建站用dw做的网页怎么连到网站上
  • 贵州安顺网站建设软件如何制作
  • 网站更改备案主体同城配送网站建设
  • 服务佳的网站建设龙岩做网站公司哪家好
  • 织梦网站后台密码wordpress上传权限设置
  • c2c网站建设需求分析做任务网站有哪些
  • 宝安品牌网站制作网站常用的优化方法有哪些
  • 太原站扩建asp.net网站开发实战
  • 个人免费网站制作网投计划
  • 网站开发案例php俄罗斯注册公司多少钱
  • 外国网站快速申请qqwordpress 默认密码
  • 如何建立内外网网站详情页设计流程
  • 韶关做网站找公司做网站注意事项
  • 做网站第一步做什么用dede做的网站首页