presto(八)——restful api之query

上一篇文章我们提到:SqlQueryManager。他是管理query语句创建、语法解析、查询状态的跟踪。

1、查询语句入口

@Path("/v1/query")
public class QueryResource
{
}
省略
 @POST
 @Produces(MediaType.APPLICATION_JSON)
 public Response createQuery(
       String statement,
       @Context HttpServletRequest servletRequest,
       @Context UriInfo uriInfo)
       Session session = createSessionForRequest(servletRequest, transactionManager, accessControl, sessionPropertyManager, queryIdGenerator.createNextQueryId());
        //调用SqlQueryManager的createQuery
      QueryInfo queryInfo = queryManager.createQuery(session, statement);
{

也就是说,这一层是基于SqlQueryManager来对外提供接口。
包括提供查询单个query的状态信息也是通过SqlQueryManager来获取。

比较特别的地方就是有一个Session,它到底是干嘛的呢?

2、Session到底是什么货

来看看session的状态:

 private final QueryId queryId;
    private final Optional<TransactionId> transactionId;
    private final boolean clientTransactionSupport;
    private final Identity identity;
    private final Optional<String> source;
    private final Optional<String> catalog;
    private final Optional<String> schema;
    private final TimeZoneKey timeZoneKey;
    private final Locale locale;
    private final Optional<String> remoteUserAddress;
    private final Optional<String> userAgent;
    private final long startTime;
    private final Map<String, String> systemProperties;
    private final Map<ConnectorId, Map<String, String>> connectorProperties;
    private final Map<String, Map<String, String>> unprocessedCatalogProperties;
    private final SessionPropertyManager sessionPropertyManager;
    private final Map<String, String> preparedStatements;

1、每一次创建query查询,都会创建一个新的session。
2、对session进行权限校验
3、保存preparedStatements,比如:

Session session = Session.builder(getSession())
                .addPreparedStatement("my_query", "SELECT * FROM orders where orderkey < ?")
                .build();
        MaterializedResult result = computeActual(session, "EXPLAIN (TYPE LOGICAL) EXECUTE my_query USING 7");
        assertEquals(getOnlyElement(result.getOnlyColumnAsSet()), getExplainPlan("SELECT * FROM orders where orderkey < 7", LOGICAL));

在session期间定义一个preparedStatement,然后可以自行填充带补充的字段。

三、只有协调器节点才有

看CoordinatorModule类中才有一下初始化QueryResource地方:

protected void setup(Binder binder){
   jaxrsBinder(binder).bind(QueryResource.class);

也就是说,只有协调器节点能提交语句,创建session,查询语句状态。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 32,481评论 18 399
  • 1. 简介 1.1 什么是 MyBatis ? MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的...
    笨鸟慢飞阅读 11,167评论 0 4
  • 这部分主要是开源Java EE框架方面的内容,包括Hibernate、MyBatis、Spring、Spring ...
    杂货铺老板阅读 5,303评论 0 2
  • 在前行的路上受阻了,迷失了方向。3个小时的座谈会从新拉回起点,不晚! 从沟通交心开始,从操练会...
    Alina_qi阅读 1,297评论 0 2
  • 清晨没有朝阳,黄昏没有夕阳。我看见正午的阳光,四处流浪。闪闪发光,刺痛了我的心脏。
    主爱阅读 1,567评论 0 0

友情链接更多精彩内容