|
24 | 24 | import net.sf.jsqlparser.expression.operators.relational.InExpression; |
25 | 25 | import net.sf.jsqlparser.expression.operators.relational.ItemsList; |
26 | 26 | import net.sf.jsqlparser.parser.CCJSqlParserUtil; |
| 27 | +import net.sf.jsqlparser.schema.Column; |
27 | 28 | import net.sf.jsqlparser.statement.select.PlainSelect; |
28 | 29 | import net.sf.jsqlparser.statement.select.Select; |
29 | 30 | import org.junit.After; |
@@ -130,5 +131,42 @@ public void visit(OracleHint hint) { |
130 | 131 | assertEquals(singleLine, holder[0].isSingleLine()); |
131 | 132 | assertEquals(hint, holder[0].getValue()); |
132 | 133 | } |
133 | | - |
| 134 | + |
| 135 | + @Test |
| 136 | + public void testCurrentTimestampExpression() throws JSQLParserException{ |
| 137 | + final List<String> columnList = new ArrayList<String>(); |
| 138 | + Select select = (Select) CCJSqlParserUtil.parse( "select * from foo where bar < CURRENT_TIMESTAMP" ); |
| 139 | + PlainSelect plainSelect = (PlainSelect) select.getSelectBody(); |
| 140 | + Expression where = plainSelect.getWhere(); |
| 141 | + where.accept(new ExpressionVisitorAdapter() { |
| 142 | + |
| 143 | + @Override |
| 144 | + public void visit(Column column) { |
| 145 | + super.visit(column); |
| 146 | + columnList.add(column.getColumnName()); |
| 147 | + } |
| 148 | + }); |
| 149 | + |
| 150 | + assertEquals(1, columnList.size()); |
| 151 | + assertEquals("bar", columnList.get(0)); |
| 152 | + } |
| 153 | + |
| 154 | + @Test |
| 155 | + public void testCurrentDateExpression() throws JSQLParserException{ |
| 156 | + final List<String> columnList = new ArrayList<String>(); |
| 157 | + Select select = (Select) CCJSqlParserUtil.parse( "select * from foo where bar < CURRENT_DATE" ); |
| 158 | + PlainSelect plainSelect = (PlainSelect) select.getSelectBody(); |
| 159 | + Expression where = plainSelect.getWhere(); |
| 160 | + where.accept(new ExpressionVisitorAdapter() { |
| 161 | + |
| 162 | + @Override |
| 163 | + public void visit(Column column) { |
| 164 | + super.visit(column); |
| 165 | + columnList.add(column.getColumnName()); |
| 166 | + } |
| 167 | + }); |
| 168 | + |
| 169 | + assertEquals(1, columnList.size()); |
| 170 | + assertEquals("bar", columnList.get(0)); |
| 171 | + } |
134 | 172 | } |
0 commit comments