39c50545444476360a839f85295f112b243bc5a4
[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     public UpsertQuery(Entity e, T object, String controllerId, boolean ignoreControllerId, boolean ignoreIdField) {
36         super(e, object, controllerId, ignoreControllerId, ignoreIdField);
37
38     }
39
40     @Override
41     protected void appendAdditionalToQuery(StringBuilder sb, List<DBKeyValuePair<String>> keyValues) {
42         sb.append(" ON DUPLICATE KEY UPDATE ");
43         boolean comma = false;
44         for (DBKeyValuePair<String> kvp : keyValues) {
45             if(kvp.getKey().equals("`id`")) {
46                 continue;
47             }
48             //do not update is-required if entry already exists
49             if (this.entity == Entity.NetworkelementConnection && kvp.getKey().equals("`is-required`")
50                     && (kvp.getValue().equals("false") || kvp.getValue().equals("0"))) {
51                 continue;
52             }
53             if (comma) {
54                 sb.append(",");
55             }
56             sb.append(String.format("%s=%s", kvp.getKey(), kvp.getValue()));
57             comma = true;
58         }
59     }
60 }