网上的教程大多都是直接配置,然后拦截到所有 SQL 了,但有些表是不分租户的。
还有就是 spring boot 初始化的时候会读表里的配置信息,这时候初始化就会报错了。
有没有什么方法让它不拦截某些 SQL ,比如搞个自定义注解,让它只拦截被标记的方法。
我是个彩笔,有没有大佬使用通俗且小白的方式回答下。感激不尽
1
guzzhao 2023-05-29 20:24:11 +08:00
|
2
qinfengge OP @guzzhao 感谢,不过这个我也看过了,它是先进的拦截器再判断是否过滤表,但是有个问题就是登录的时候还没有 token ,获取不到 TenantId😂
|
4
jptx 2023-05-29 22:27:24 +08:00
`TenantLineHandler` 中的 `ignoreTable` 方法中,从当前线程上下文获取用户信息,如果没有用户信息,则返回 true ,代表不按租户 ID 过滤
|
5
ccw4wcc 2023-05-30 11:24:44 +08:00
可以写一个单独的 mapper 方法,然后用注解,忽略掉租户拦截器吧
|
6
freeup 2023-05-30 11:50:16 +08:00
可以根据表结构建立元数据,通过解析 sql 拿到每个表名,然后根据表名查询元数据,看看是否有租户字段,在进行过滤,我之前的项目就是这样做的,通过 mybatis 插件,拦截所有 sql 基于元数据 进行后续逻辑处理
|
7
issakchill 2023-05-30 14:57:37 +08:00
很多方法的呀 写死表名 或者表名打注解 TableInfoHelper 都能拿到
|
8
qinfengge OP 已经可以了,感谢各位大佬回复。还是用的官方文档里面的方式。出错的原因是登录的时候还是主线程,但是拦截到的却是子线程,导致获取不到 threadlocal 的值😅
|