P15GEN2\59518
2025-10-10 9f6890646993d16260d4201d613c092132856127
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
package foundation.value;
 
import java.sql.Timestamp;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Date;
 
import foundation.server.config.DBaseType;
import foundation.util.Util;
import oracle.sql.TIMESTAMP;
 
 
public class TimeStampTranslator extends ITranslator {
 
    private static String DateTimeFormat = "yyyy-MM-dd HH:mm:ss";
    private static String DateFormat = "yyyy-MM-dd";
    private DateFormat dateFormater;
    
            
    public TimeStampTranslator() {
        dateFormater = new SimpleDateFormat(DateFormat);
    }
    
    @Override
    public Timestamp load(Object value){
        if (value == null || value == ValueType.Null) {
            return null;
        }
        
        if (value instanceof Timestamp) {
            return (Timestamp)value;
        } else if (value instanceof TIMESTAMP) {
            return (Timestamp)value;
        } else if (value instanceof Date) {
            Date date = (Date) value;
            return new Timestamp(date.getTime());
        } else if (value instanceof Long) {
            return new Timestamp(Long.valueOf((long)value));
        } 
        
        String dateString = value.toString();
        return Timestamp.valueOf(dateString);
    }
    
    @Override
    public Timestamp load(String value) throws Exception {
        if (value == null) {
            return null;
        }
        
        return Timestamp.valueOf(value);
    }
    
    public String toString(Object value) throws Exception {
        if (value == null || value == ValueType.Null) {
            return null;
        }
        
        Date date = (Date)value;
        return dateFormater.format(date);
    }
    
    public String toSqlString(DBaseType dbaseType, Object value) throws Exception {
        if (value == null || value == ValueType.Null) {
            return "null";
        }
        
        Timestamp date = toTimestamp(value);
        
        if (dbaseType.isMySQL()) {
            return "\"" + dateFormater.format(date) + "\"";
        }
        else if (dbaseType.isSQLServer()) {
            return "'" + dateFormater.format(date) + "'";
        }
        else if (dbaseType.isOracle()) {
            return "to_timestamp(\'" + dateFormater.format(date) + "\', 'YYYY-MM-dd HH24:mi:ss')";
        }
        
        return "\"" + dateFormater.format(date) + "\"";
    }
    
    public String toJSONString(Object value) throws Exception {
        if (value == null || value == ValueType.Null) {
            return "null";
        }
        
        Date date = (Date)value;
        return "\"" + dateFormater.format(date) + "\"";
    }
    
    public String toSchemaString(Object value) throws Exception {
        if (value == null || value == ValueType.Null) {
            return "";
        }
        
        Date date = (Date)value;
        return "\"" + dateFormater.format(date) + "\"";
    }
 
    public Timestamp toTimestamp(Object object) throws Exception {
        if (object == null || object == ValueType.Null) {
            return null;
        }
        
        if (object instanceof String) {
            String dateString = object.toString();
            return Timestamp.valueOf(dateString);
        } else if (object instanceof Date) {
            Date date = (Date) object;
            return new Timestamp(date.getTime());
        } else if (object instanceof Long) {
            return new Timestamp(Long.valueOf((long)object));
        } else if (object instanceof Timestamp) {
            return (Timestamp)object;
        } else if (object instanceof TIMESTAMP) {
            return (Timestamp)object;
        }
        return null;
    }
    
    @Override
    public Object toTranslatorTypeValue(Object value) throws Exception {
        return load(value);
    }
    
    @Override
    public void setFormat(String format) {
        if (Util.isEmpty(format)) {
            format = DateTimeFormat;
        }
        
        this.format = format;
        dateFormater = new SimpleDateFormat(format);
    }
 
    @Override
    public String checkType(Object object) {
        return null;
    }
 
    @Override
    public Class<?> getDataClass() {
        return Date.class;
    }
}