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

com.wavemaker.runtime.data.dialect.WMPostgresIdentityColumnSupport Maven / Gradle / Ivy

The newest version!
/*******************************************************************************
 * Copyright (C) 2022-2023 WaveMaker, Inc.
 *
 * 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 com.wavemaker.runtime.data.dialect;

import org.apache.commons.lang3.StringUtils;
import org.hibernate.dialect.identity.PostgreSQL81IdentityColumnSupport;

/**
 * @author Dilip Kumar
 * @since 19/4/16
 */
public class WMPostgresIdentityColumnSupport extends PostgreSQL81IdentityColumnSupport {

    public WMPostgresIdentityColumnSupport() {
        super();
    }

    /**
     * PostgresDialect not handling cases where table or columns names in mixed or upper case.
     * 

* Issues like: whenever any table/column name in non lower case, those are wrapped in double quotes ("). *

* In these cases invalid IdentitySelectString got generated like: "select currval('schema."Table"_"COLUMN"_seq'), * it should be generated as "select currval('schema."Table_COLUMN_seq"')" * * @param table name of the table, including schema * @param column name of the column * @param type type * * @return "select currval('schema.table_column_seq')" or "select currval('schema."TABLE_COLUMN_seq"') */ @Override public String getIdentitySelectString(String table, String column, int type) { StringBuilder sb = new StringBuilder(); sb.append("select currval('"); String[] tableAndSchema = table.split("\\."); int tableIndex = 0; if (tableAndSchema.length > 1) { sb.append(tableAndSchema[tableIndex++]); // appending schema name sb.append("."); } String tableName = tableAndSchema[tableIndex]; boolean quoted = false; if (StringUtils.contains(tableName, "\"") || StringUtils.contains(column, "\"")) { quoted = true; } if (quoted) { sb.append("\""); } sb.append(tableName.replace("\"", "")) .append("_") .append(column.replace("\"", "")); sb.append("_seq"); if (quoted) { sb.append("\""); } sb.append("')"); return sb.toString(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy