BrightSide Workbench Full Report + Source Code
PostprocessClause.java
Go to the documentation of this file.
1 /*
2  * TurrĂ³ i Cutiller Foundation. License notice.
3  * Copyright (C) 2021 Lluis TurrĂ³ Cutiller <http://www.turro.org/>
4  *
5  * This program is free software: you can redistribute it and/or modify
6  * it under the terms of the GNU Affero General Public License as published by
7  * the Free Software Foundation, either version 3 of the License, or
8  * (at your option) any later version.
9  *
10  * This program is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  * GNU Affero General Public License for more details.
14  *
15  * You should have received a copy of the GNU Affero General Public License
16  * along with this program. If not, see <http://www.gnu.org/licenses/>.
17  */
18 
19 package org.turro.indicator;
20 
21 import java.util.List;
22 import org.turro.elephant.db.WhereClause;
23 
28 public class PostprocessClause {
29 
30  private String table, entityPath;
31  private List<String> springPaths;
32  private IndicatorVariable variable;
33 
34  public static PostprocessClause load(String table) {
35  return new PostprocessClause(table);
36  }
37 
38  public PostprocessClause setEntityPath(String entityPath) {
39  this.entityPath = entityPath;
40  return this;
41  }
42 
43  public PostprocessClause setSpringPaths(List<String> springPaths) {
44  this.springPaths = springPaths;
45  return this;
46  }
47 
49  WhereClause wc = new WhereClause();
50  wc.addClause("select new org.turro.ranking.GenericRanking(");
51  wc.addClause("'" + entityPath + "', concept, sum(ranking))");
52  wc.addClause("from " + table);
53  wc.addIn("where", "entityPath", springPaths);
54  wc.addClause("group by concept");
55  wc.addClause("having sum(ranking) <> 0");
56  return wc;
57  }
58 
59  private PostprocessClause(String table) {
60  this.table = table;
61  }
62 
63 }
void addIn(String operator, String field, List values)
PostprocessClause setSpringPaths(List< String > springPaths)
static PostprocessClause load(String table)
PostprocessClause setEntityPath(String entityPath)