com.querydsl.sql.dml.AbstractSQLClause Maven / Gradle / Ivy
The newest version!
/*
* Copyright 2015, The Querydsl Team (http://www.querydsl.com/team)
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
* http://www.apache.org/licenses/LICENSE-2.0
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.querydsl.sql.dml;
import java.sql.*;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import java.util.Map;
import java.util.logging.Level;
import java.util.logging.Logger;
import java.util.function.Supplier;
import org.jetbrains.annotations.Nullable;
import com.querydsl.core.QueryMetadata;
import com.querydsl.core.dml.DMLClause;
import com.querydsl.core.types.ParamExpression;
import com.querydsl.core.types.ParamNotSetException;
import com.querydsl.core.types.Path;
import com.querydsl.sql.*;
/**
* {@code AbstractSQLClause} is a superclass for SQL based DMLClause implementations
*
* @param concrete subtype
*
* @author tiwe
*/
public abstract class AbstractSQLClause> implements DMLClause {
protected final Configuration configuration;
protected final SQLListeners listeners;
protected boolean useLiterals;
protected SQLListenerContextImpl context;
@Nullable
private Supplier connProvider;
@Nullable
private Connection conn;
public AbstractSQLClause(Configuration configuration) {
this.configuration = configuration;
this.listeners = new SQLListeners(configuration.getListeners());
this.useLiterals = configuration.getUseLiterals();
}
public AbstractSQLClause(Configuration configuration, Supplier connProvider) {
this(configuration);
this.connProvider = connProvider;
}
public AbstractSQLClause(Configuration configuration, Connection conn) {
this(configuration);
this.conn = conn;
}
/**
* Add a listener
*
* @param listener listener to add
*/
public void addListener(SQLListener listener) {
listeners.add(listener);
}
/**
* Clear the internal state of the clause
*/
public abstract void clear();
/**
* Called to create and start a new SQL Listener context
*
* @param connection the database connection
* @param metadata the meta data for that context
* @param entity the entity for that context
* @return the newly started context
*/
protected SQLListenerContextImpl startContext(Connection connection, QueryMetadata metadata, RelationalPath> entity) {
SQLListenerContextImpl context = new SQLListenerContextImpl(metadata, connection, entity);
listeners.start(context);
return context;
}
/**
* Called to make the call back to listeners when an exception happens
*
* @param context the current context in play
* @param e the exception
*/
protected void onException(SQLListenerContextImpl context, Exception e) {
context.setException(e);
listeners.exception(context);
}
/**
* Called to end a SQL listener context
*
* @param context the listener context to end
*/
protected void endContext(SQLListenerContextImpl context) {
listeners.end(context);
this.context = null;
}
protected SQLBindings createBindings(QueryMetadata metadata, SQLSerializer serializer) {
String queryString = serializer.toString();
List