2 * ============LICENSE_START=======================================================
3 * ONAP : ccsdk features
4 * ================================================================================
5 * Copyright (C) 2020 highstreet technologies GmbH Intellectual Property.
7 * ================================================================================
8 * Licensed under the Apache License, Version 2.0 (the "License");
9 * you may not use this file except in compliance with the License.
10 * You may obtain a copy of the License at
12 * http://www.apache.org/licenses/LICENSE-2.0
14 * Unless required by applicable law or agreed to in writing, software
15 * distributed under the License is distributed on an "AS IS" BASIS,
16 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17 * See the License for the specific language governing permissions and
18 * limitations under the License.
19 * ============LICENSE_END=========================================================
22 package org.onap.ccsdk.features.sdnr.wt.dataprovider.database.sqldb.query;
24 import java.util.List;
25 import org.onap.ccsdk.features.sdnr.wt.dataprovider.database.sqldb.query.filters.DBKeyValuePair;
26 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.Entity;
27 import org.opendaylight.yangtools.yang.binding.DataObject;
29 public class UpsertQuery<T extends DataObject> extends InsertQuery<T> {
31 public UpsertQuery(Entity e, T object, String controllerId) {
32 super(e, object, controllerId);
37 protected void appendAdditionalToQuery(StringBuilder sb, List<DBKeyValuePair<String>> keyValues) {
38 sb.append(" ON DUPLICATE KEY UPDATE ");
39 boolean comma = false;
40 for (DBKeyValuePair<String> kvp : keyValues) {
41 if(kvp.getKey().equals("`id`")) {
44 //do not update is-required if entry already exists
45 if (this.entity == Entity.NetworkelementConnection && kvp.getKey().equals("`is-required`")
46 && (kvp.getValue().equals("false") || kvp.getValue().equals("0"))) {
52 sb.append(String.format("%s=%s", kvp.getKey(), kvp.getValue()));