网上的教程大多都是直接配置,然后拦截到所有 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 的值 |