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

com.hazelcast.jet.sql.impl.connector.jdbc.UpdateQueryBuilder Maven / Gradle / Ivy

There is a newer version: 5.5.0
Show newest version
/*
 * Copyright 2024 Hazelcast Inc.
 *
 * Licensed under the Hazelcast Community License (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://hazelcast.com/hazelcast-community-license
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package com.hazelcast.jet.sql.impl.connector.jdbc;

import com.hazelcast.shaded.com.google.common.primitives.Ints;
import com.hazelcast.shaded.org.apache.calcite.rex.RexNode;
import com.hazelcast.shaded.org.apache.calcite.sql.SqlDialect;
import com.hazelcast.shaded.org.apache.calcite.sql.SqlNode;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

class UpdateQueryBuilder extends AbstractQueryBuilder {

    private final List dynamicParams = new ArrayList<>();
    private final List inputRefs = new ArrayList<>();

    UpdateQueryBuilder(
            JdbcTable table,
            SqlDialect dialect,
            List fieldNames,
            List expressions,
            RexNode predicate,
            boolean hasInput
    ) {
        super(table, dialect);

        assert fieldNames.size() == expressions.size();

        StringBuilder sb = new StringBuilder();
        sb.append("UPDATE ");
        dialect.quoteIdentifier(sb, Arrays.asList(table.getExternalName()));

        sb.append(" SET ");
        ParamCollectingVisitor dynamicParamVisitor = new ParamCollectingVisitor(dynamicParams);
        for (int i = 0; i < fieldNames.size(); i++) {
            RexNode rexNode = expressions.get(i);

            SqlNode sqlNode = context.toSql(null, rexNode);
            sqlNode.accept(dynamicParamVisitor);

            String externalFieldName = table.getField(fieldNames.get(i)).externalName();
            dialect.quoteIdentifier(sb, externalFieldName);
            sb.append('=');
            sb.append(sqlNode.toSqlString(dialect).toString());
            if (i < fieldNames.size() - 1) {
                sb.append(", ");
            }
        }

        if (predicate != null) {
            appendPredicate(sb, predicate, dynamicParams);
        } else if (hasInput) {
            appendPrimaryKeyPredicate(sb, inputRefs);
        }

        query = sb.toString();
    }

    int[] dynamicParams() {
        return Ints.toArray(dynamicParams);
    }

    int[] inputRefs() {
        return Ints.toArray(inputRefs);
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy