svn-gvsig-desktop / trunk / org.gvsig.desktop / org.gvsig.desktop.plugin / org.gvsig.sqlite / org.gvsig.sqlite.provider / src / main / java / org / gvsig / sqlite / dal / expressionbuilderformatter / Date.java @ 47579
History | View | Annotate | Download (2.34 KB)
1 |
package org.gvsig.sqlite.dal.expressionbuilderformatter; |
---|---|
2 |
|
3 |
import java.time.LocalDate; |
4 |
import java.time.LocalDateTime; |
5 |
import java.time.ZoneId; |
6 |
import java.time.format.DateTimeFormatter; |
7 |
import java.time.temporal.ChronoField; |
8 |
import java.time.temporal.TemporalField; |
9 |
import java.util.List; |
10 |
import org.apache.commons.lang3.StringUtils; |
11 |
import org.gvsig.expressionevaluator.ExpressionBuilder; |
12 |
import static org.gvsig.expressionevaluator.ExpressionBuilder.FUNCTION_TIME; |
13 |
import org.gvsig.expressionevaluator.ExpressionBuilder.Function; |
14 |
import org.gvsig.expressionevaluator.ExpressionBuilder.Value; |
15 |
import org.gvsig.expressionevaluator.Formatter; |
16 |
import org.gvsig.fmap.dal.SQLBuilder; |
17 |
import org.gvsig.fmap.dal.store.jdbc2.spi.expressionbuilder.formatters.$Constant; |
18 |
import org.gvsig.tools.dataTypes.DataTypeUtils; |
19 |
|
20 |
/**
|
21 |
*
|
22 |
* @author jjdelcerro
|
23 |
*/
|
24 |
public class Date implements Formatter<Value> { |
25 |
|
26 |
private final SQLBuilder sqlbuilder; |
27 |
private final Formatter<Value> formatter; |
28 |
|
29 |
public Date(SQLBuilder sqlbuilder, Formatter<Value> formatter) { |
30 |
this.sqlbuilder = sqlbuilder;
|
31 |
this.formatter = formatter;
|
32 |
} |
33 |
|
34 |
@Override
|
35 |
public boolean canApply(ExpressionBuilder.Value value) { |
36 |
if (value instanceof ExpressionBuilder.Function) { |
37 |
if( StringUtils.equalsIgnoreCase(ExpressionBuilder.FUNCTION_DATE, ((Function) value).name()) ) {
|
38 |
List<Value> parameters = ((Function) value).parameters();
|
39 |
if( parameters.size()==1) { |
40 |
Value p1 = parameters.get(0);
|
41 |
if( $Constant.isConstant(p1) ) { |
42 |
return true; |
43 |
} |
44 |
|
45 |
} |
46 |
} |
47 |
} |
48 |
return false; |
49 |
} |
50 |
|
51 |
@Override
|
52 |
public String format(Value function) { |
53 |
List<Value> parameters = ((Function) function).parameters();
|
54 |
Value p1 = parameters.get(0);
|
55 |
ExpressionBuilder.Constant p1value = $Constant.resolveAsConstant(this.sqlbuilder, this.formatter, p1); |
56 |
LocalDateTime localDate = DataTypeUtils.toLocalDateTime(p1value.value()); |
57 |
|
58 |
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd");
|
59 |
|
60 |
// long t = localDate.atZone(ZoneId.systemDefault()).toInstant().toEpochMilli();
|
61 |
|
62 |
String r = "('"+localDate.format(formatter)+"')"; |
63 |
return r;
|
64 |
} |
65 |
|
66 |
} |