e6f1e13cbaaa59826c81493bf0143a5f201a34b8
[ccsdk/features.git] /
1 /*
2  * ============LICENSE_START=======================================================
3  * ONAP : ccsdk features
4  * ================================================================================
5  * Copyright (C) 2020 highstreet technologies GmbH Intellectual Property.
6  * All rights reserved.
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
11  *
12  *     http://www.apache.org/licenses/LICENSE-2.0
13  *
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=========================================================
20  *
21  */
22 package org.onap.ccsdk.features.sdnr.wt.dataprovider.database.sqldb.query;
23
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;
28
29 public class UpsertQuery<T extends DataObject> extends InsertQuery<T> {
30
31     public UpsertQuery(Entity e, T object, String controllerId) {
32         super(e, object, controllerId);
33
34     }
35
36     @Override
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`")) {
42                 continue;
43             }
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"))) {
47                 continue;
48             }
49             if (comma) {
50                 sb.append(",");
51             }
52             sb.append(String.format("%s=%s", kvp.getKey(), kvp.getValue()));
53             comma = true;
54         }
55     }
56 }