All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.rivulet.net.sf.jsqlparser.util.deparser.UpdateDeParser Maven / Gradle / Ivy

The newest version!
/*
 * #%L
 * JSQLParser library
 * %%
 * Copyright (C) 2004 - 2013 JSQLParser
 * %%
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as 
 * published by the Free Software Foundation, either version 2.1 of the 
 * License, or (at your option) any later version.
 * 
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Lesser Public License for more details.
 * 
 * You should have received a copy of the GNU General Lesser Public 
 * License along with this program.  If not, see
 * .
 * #L%
 */
package net.sf.jsqlparser.util.deparser;

import java.util.Iterator;

import net.sf.jsqlparser.expression.Expression;
import net.sf.jsqlparser.expression.ExpressionVisitor;
import net.sf.jsqlparser.expression.ExpressionVisitorAdapter;
import net.sf.jsqlparser.schema.Column;
import net.sf.jsqlparser.statement.select.Join;
import net.sf.jsqlparser.statement.select.PlainSelect;
import net.sf.jsqlparser.statement.update.Update;
import net.sf.jsqlparser.statement.select.Select;
import net.sf.jsqlparser.statement.select.SelectVisitor;
import net.sf.jsqlparser.statement.select.OrderByVisitor;
import net.sf.jsqlparser.statement.select.OrderByElement;
import net.sf.jsqlparser.statement.select.SelectExpressionItem;
import net.sf.jsqlparser.statement.select.SelectVisitorAdapter;

/**
 * A class to de-parse (that is, tranform from JSqlParser hierarchy into a string) an
 * {@link net.sf.jsqlparser.statement.update.Update}
 */
public class UpdateDeParser implements OrderByVisitor {

    protected StringBuilder buffer = new StringBuilder();
    private ExpressionVisitor expressionVisitor = new ExpressionVisitorAdapter();
    private SelectVisitor selectVisitor = new SelectVisitorAdapter();

    public UpdateDeParser() {
    }

    /**
     * @param expressionVisitor a {@link ExpressionVisitor} to de-parse expressions. It has to share
     * the same
* StringBuilder (buffer parameter) as this object in order to work * @param selectVisitor a {@link SelectVisitor} to de-parse * {@link net.sf.jsqlparser.statement.select.Select}s. It has to share the same
* StringBuilder (buffer parameter) as this object in order to work * @param buffer the buffer that will be filled with the select */ public UpdateDeParser(ExpressionVisitor expressionVisitor, SelectVisitor selectVisitor, StringBuilder buffer) { this.buffer = buffer; this.expressionVisitor = expressionVisitor; this.selectVisitor = selectVisitor; } public StringBuilder getBuffer() { return buffer; } public void setBuffer(StringBuilder buffer) { this.buffer = buffer; } public void deParse(Update update) { buffer.append("UPDATE ").append(PlainSelect.getStringList(update.getTables(), true, false)). append(" SET "); if (!update.isUseSelect()) { for (int i = 0; i < update.getColumns().size(); i++) { Column column = update.getColumns().get(i); column.accept(expressionVisitor); buffer.append(" = "); Expression expression = update.getExpressions().get(i); expression.accept(expressionVisitor); if (i < update.getColumns().size() - 1) { buffer.append(", "); } } } else { if (update.isUseColumnsBrackets()) { buffer.append("("); } for (int i = 0; i < update.getColumns().size(); i++) { if (i != 0) { buffer.append(", "); } Column column = update.getColumns().get(i); column.accept(expressionVisitor); } if (update.isUseColumnsBrackets()) { buffer.append(")"); } buffer.append(" = "); buffer.append("("); Select select = update.getSelect(); select.getSelectBody().accept(selectVisitor); buffer.append(")"); } if (update.getFromItem() != null) { buffer.append(" FROM ").append(update.getFromItem()); if (update.getJoins() != null) { for (Join join : update.getJoins()) { if (join.isSimple()) { buffer.append(", ").append(join); } else { buffer.append(" ").append(join); } } } } if (update.getWhere() != null) { buffer.append(" WHERE "); update.getWhere().accept(expressionVisitor); } if (update.getOrderByElements() != null) { new OrderByDeParser(expressionVisitor, buffer).deParse(update.getOrderByElements()); } if (update.getLimit() != null) { new LimitDeparser(buffer).deParse(update.getLimit()); } if (update.isReturningAllColumns()) { buffer.append(" RETURNING *"); } else if (update.getReturningExpressionList() != null) { buffer.append(" RETURNING "); for (Iterator iter = update.getReturningExpressionList(). iterator(); iter.hasNext();) { buffer.append(iter.next().toString()); if (iter.hasNext()) { buffer.append(", "); } } } } public ExpressionVisitor getExpressionVisitor() { return expressionVisitor; } public void setExpressionVisitor(ExpressionVisitor visitor) { expressionVisitor = visitor; } @Override public void visit(OrderByElement orderBy) { orderBy.getExpression().accept(expressionVisitor); if (!orderBy.isAsc()) { buffer.append(" DESC"); } else if (orderBy.isAscDescPresent()) { buffer.append(" ASC"); } if (orderBy.getNullOrdering() != null) { buffer.append(' '); buffer. append(orderBy.getNullOrdering() == OrderByElement.NullOrdering.NULLS_FIRST ? "NULLS FIRST" : "NULLS LAST"); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy