trino sql 中怎么传递变量

21次阅读

共计 412 个字符,预计需要花费 2 分钟才能阅读完成。

各位大佬们,目前我的需求是这样:
1: 根据每个单号决定用户 sql 的权限,比如单号是 1,这个单号只有 userId,systemId 的查询权限,但是用户如果写了 select userId,systemId,temp_ip from system_table, 那 temp_ip 这个字段的权限不是该单号所具有的权限,那么就会报错。
2: 目前使用 trino 的 SystemAccessControl 中的 checkCanSelectFromColumns 可以解析进行控制权限.
3: 但是还有一个问题就是,我怎么把单号传给 trino,让 trino 在 checkCanSelectFromColumns 中取到这个单号,从而从权限表中找到用户所配置的单号对应的表和字段,查了下文档,trino 目前不支持 session 传参数的方法,也没有办法在 sql 中直接 set orderId = 1,也没有办法动态修改 sql,从动态的 sql 中取出单号,各位大佬有什么好的方案吗?

正文完
 0