All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.vertx.db2client.impl.codec.DB2PreparedStatement Maven / Gradle / Ivy

There is a newer version: 5.0.0.CR1
Show newest version
/*
 * Copyright (C) 2019,2020 IBM Corporation
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package io.vertx.db2client.impl.codec;

import java.util.Map;
import java.util.UUID;
import java.util.concurrent.ConcurrentHashMap;

import io.vertx.core.impl.logging.Logger;
import io.vertx.core.impl.logging.LoggerFactory;
import io.vertx.db2client.impl.drda.Cursor;
import io.vertx.db2client.impl.drda.Section;
import io.vertx.sqlclient.impl.ParamDesc;
import io.vertx.sqlclient.impl.PreparedStatement;
import io.vertx.sqlclient.impl.RowDesc;
import io.vertx.sqlclient.impl.TupleInternal;

class DB2PreparedStatement implements PreparedStatement {

  private static final Logger LOG = LoggerFactory.getLogger(DB2PreparedStatement.class);

  final String sql;
  final DB2ParamDesc paramDesc;
  final DB2RowDesc rowDesc;
  final Section section;

  private final Map activeQueries = new ConcurrentHashMap<>(4);

  public static class QueryInstance {
    final String cursorId;
    long queryInstanceId;
    Cursor cursor;

    QueryInstance(String cursorId) {
      if (LOG.isDebugEnabled())
        LOG.debug("Creating new queryInstance with id=" + cursorId);
      this.cursorId = cursorId;
    }
  }

  DB2PreparedStatement(String sql, DB2ParamDesc paramDesc, DB2RowDesc rowDesc, Section section) {
    this.paramDesc = paramDesc;
    this.rowDesc = rowDesc;
    this.sql = sql;
    this.section = section;
  }

  @Override
  public ParamDesc paramDesc() {
    return paramDesc;
  }

  @Override
  public RowDesc rowDesc() {
    return rowDesc;
  }

  @Override
  public String sql() {
    return sql;
  }

  @Override
  public String prepare(TupleInternal values) {
    return paramDesc.prepare(values);
  }

  QueryInstance getQueryInstance(String cursorId) {
    cursorId = cursorId == null ? UUID.randomUUID().toString() : cursorId;
    return activeQueries.computeIfAbsent(cursorId, c -> {
      return new QueryInstance(c);
    });
  }

  void closeQuery(QueryInstance query) {
    LOG.debug("Closing queryInstance " + query.cursorId);
    activeQueries.remove(query.cursorId);
  }

  void close() {
    activeQueries.values().stream().forEach(this::closeQuery);
    section.release();
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy