广州海珠区网站建设,门户网站开发一般多少钱,wordpress密码文件夹,如何进入官方网站目录 Mybatis分页插件原理#xff1f;
ThreadLocal?
树形表的标记字段是什么#xff1f;如何查询MySQL树形表#xff1f;
Mybatis的ResultType和ResultMap的区别#xff1f;
#{}和${}有什么区别#xff1f;
系统如何处理异常#xff1f; Mybatis分页插件原理#…目录 Mybatis分页插件原理
ThreadLocal?
树形表的标记字段是什么如何查询MySQL树形表
Mybatis的ResultType和ResultMap的区别
#{}和${}有什么区别
系统如何处理异常 Mybatis分页插件原理
首先分页参数放到ThreadLocal中拦截执行得到sql根据数据库类型添加对应的分页语句将重写sql。例如select * from table where a转换为 select count(*) from table where a)和select * from table where a limit ,计算出了total总条数pageNum当前第几页pageSize每页大小和当前页的数据是否为首页是否为尾页总页数等。
ThreadLocal?
ThreadLocal叫做线程变量意思是ThreadLocal中填充的变量属于当前线程该变量对其他线程而言是隔离的也就是说该变量是当前线程独有的变量。ThreadLocal为变量在每个线程中都创建了一个副本那么每个线程可以访问自己内部的副本变量。
ThreadLoal 变量线程局部变量同一个 ThreadLocal 所包含的对象在不同的 Thread 中有不同的副本。这里有几点需要注意:
因为每个 Thread 内有自己的实例副本且该副本只能由当前 Thread 使用。这是也是 ThreadLocal 命名的由来。既然每个 Thread 有自己的实例副本且其它 Thread 不可访问那就不存在多线程间共享的问题。
ThreadLocal 提供了线程本地的实例。它与普通变量的区别在于每个使用该变量的线程都会初始化一个完全独立的实例副本。ThreadLocal 变量通常被private static修饰。当一个线程结束时它所使用的所有 ThreadLocal 相对的实例副本都可被回收。
总的来说ThreadLocal 适用于每个线程需要自己独立的实例且该实例需要在多个方法中被使用也即变量在线程间隔离而在方法或类间共享的场景 ThreadLocalT其实是与线程绑定的一个变量。ThreadLocal和Synchonized都用于解决多线程并发访问。
但是ThreadLocal与synchronized有本质的区别
1、Synchronized用于线程间的数据共享而ThreadLocal则用于线程间的数据隔离。
2、Synchronized是利用锁的机制使变量或代码块在某一时该只能被一个线程访问。而ThreadLocal为每一个线程都提供了变量的副本
使得每个线程在某一时间访问到的并不是同一个对象这样就隔离了多个线程对数据的数据共享。
而Synchronized却正好相反它用于在多个线程间通信时能够获得数据共享。
一句话理解ThreadLocalthreadlocl是作为当前线程中属性ThreadLocalMap集合中的某一个Entry的key值Entrythreadlocl,value虽然不同的线程之间threadlocal这个key值是一样但是不同的线程所拥有的ThreadLocalMap是独一无二的也就是不同的线程间同一个ThreadLocalkey对应存储的值(value)不一样从而到达了线程间变量隔离的目的但是在同一个线程中这个value变量地址是一样的。 以上关于ThreadLocal转载自史上最强ThreadLocal详解
树形表的标记字段是什么如何查询MySQL树形表
标记字段是parentid即父节点的id。
查询一个树形表的方法
1当层级固定时可以用表的自连接查询 例如SELECT * FROM teachplan one inner JOIN teachplan two on two.parentid one.id where one.parentid 0 AND one.course_id 117
2如果想灵活查询每个层级使用MySQL递归的方法使用with RECURSIVE实现
Mybatis的ResultType和ResultMap的区别
ResultType:指定映射类型只要查询的字段名和类型的属性名匹配可以自动映射
ResultMap:自定义映射规则当查询的字段名和映射类型的属性不匹配时可以通过ResultMap自定义映射规则也可以实现一对多一对一映射。
#{}和${}有什么区别
#{}是一个占位符可以防止sql注入。
${}用在动态sql拼接字符串可能导致sql注入。
系统如何处理异常
自定义一个统一的异常处理器去捕获并处理异常。
使用控制器增加注解ControllerAdvice和异常处理注解ExceptionHandler来实现
1处理自定义异常
程序在编写代码时根据校验结果主动抛出自定义异常类对象抛出异常时指定详细的异常信息异常处理器捕获异常信息记录异常日志并响应给用户。
2)处理未知异常
接口执行过程中的一些运行时异常也会由异常处理器统一捕获记录异常日志统一响应给用户500错误在异常处理器中还可以针对某个异常类型进行单独处理。 请求参数的合法性校验如何做
使用基于JSR303的校验框架实现SpringBoot提供了JSR-303的支持它就是spring-boot-starter-validation,它包括了很多校验规则在controller方法上开启校验。业务逻辑的校验在service中进行多个接口共用一个类型时可以开启校验分组。