forked from JSQLParser/JSqlParser
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCreateIndexDeParser.java
More file actions
69 lines (55 loc) · 1.88 KB
/
CreateIndexDeParser.java
File metadata and controls
69 lines (55 loc) · 1.88 KB
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
/*-
* #%L
* JSQLParser library
* %%
* Copyright (C) 2004 - 2019 JSQLParser
* %%
* Dual licensed under GNU LGPL 2.1 or Apache License 2.0
* #L%
*/
package net.sf.jsqlparser.util.deparser;
import static java.util.stream.Collectors.joining;
import net.sf.jsqlparser.statement.create.index.CreateIndex;
import net.sf.jsqlparser.statement.create.table.Index;
public class CreateIndexDeParser extends AbstractDeParser<CreateIndex> {
public CreateIndexDeParser(StringBuilder buffer) {
super(buffer);
}
@Override
public void deParse(CreateIndex createIndex) {
Index index = createIndex.getIndex();
builder.append("CREATE ");
if (index.getType() != null) {
builder.append(index.getType());
builder.append(" ");
}
builder.append("INDEX ");
if (createIndex.isUsingIfNotExists()) {
builder.append("IF NOT EXISTS ");
}
builder.append(index.getName());
String using = index.getUsing();
if (using != null && createIndex.isIndexTypeBeforeOn()) {
builder.append(" USING ");
builder.append(using);
}
builder.append(" ON ");
builder.append(createIndex.getTable().getFullyQualifiedName());
if (using != null && !createIndex.isIndexTypeBeforeOn()) {
builder.append(" USING ");
builder.append(using);
}
if (index.getColumnsNames() != null) {
builder.append(" (");
builder.append(index.getColumnWithParams().stream()
.map(Index.ColumnParams::toString)
.collect(joining(", ")));
builder.append(")");
}
if (createIndex.getTailParameters() != null) {
for (String param : createIndex.getTailParameters()) {
builder.append(" ").append(param);
}
}
}
}