com.viiyue.plugins.mybatis.condition.UpdateExample Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of mybatis-mapper Show documentation
Show all versions of mybatis-mapper Show documentation
Mybatis generic mapper plugin for solving most basic operations,
simplifying sql syntax and improving dynamic execution efficiency
/**
* Copyright (C) 2017 the original author or authors.
*
* 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.viiyue.plugins.mybatis.condition;
import java.util.Arrays;
import java.util.LinkedHashSet;
import java.util.Map;
import java.util.Set;
import org.apache.ibatis.mapping.SqlCommandType;
import com.viiyue.plugins.mybatis.Constants;
import com.viiyue.plugins.mybatis.enums.ExpressionStyle;
import com.viiyue.plugins.mybatis.metadata.Entity;
import com.viiyue.plugins.mybatis.metadata.Property;
import com.viiyue.plugins.mybatis.template.builder.ColumnBuilder;
import com.viiyue.plugins.mybatis.utils.BeanUtil;
import com.viiyue.plugins.mybatis.utils.ObjectUtil;
import com.viiyue.plugins.mybatis.utils.PropertyFilter;
import com.viiyue.plugins.mybatis.utils.StringAppender;
/**
* Example update conditions
*
* @author tangxbai
* @since 1.1.0
*/
public final class UpdateExample extends AbstractExample {
private final StringAppender updates;
private final ColumnBuilder column;
private final WhereExample where;
private final PropertyFilter filter;
private final ExpressionStyle expressionStyle;
private Set bindNames;
protected UpdateExample( Entity entity ) {
super( entity );
this.updates = new StringAppender();
this.column = new ColumnBuilder( entity );
this.where = new WhereExample( this );
this.filter = new PropertyFilter( entity, SqlCommandType.UPDATE );
this.expressionStyle = entity.getExpressionStyle();
}
public UpdateExample includes( String ... properties ) {
this.filter.includes( properties );
return this;
}
public UpdateExample excludes( String ... properties ) {
this.filter.excludes( properties );
return this;
}
public UpdateExample set( String ... properties ) {
if ( ObjectUtil.isNotEmpty( properties ) ) {
this.bindNames = new LinkedHashSet( Arrays.asList( properties ) );
}
return this;
}
public UpdateExample values( Object ... values ) {
if ( bindNames != null && ObjectUtil.isNotEmpty( values ) ) {
int index = 0, size = values.length;
for ( String name : bindNames ) {
putParameter( name, index < size ? values[ index ++ ] : null );
}
this.filter.dynamic( bindNames, getParameters() );
}
return this;
}
public UpdateExample bind( Object modelInstance ) {
Set bindNames = BeanUtil.getPropertiesIfNotNull( modelInstance );
Map bindValues = BeanUtil.getPropertyValues();
this.bindNames = bindNames;
this.putParameters( bindValues );
this.filter.dynamic( bindNames, bindValues );
return this;
}
public WhereExample when() {
return where;
}
@Override
protected String getWherePart( boolean isLogicallyDelete, boolean isDeleteValue ) {
return where.getWherePart( isLogicallyDelete, isDeleteValue );
}
@Override
protected String getModifyPart() {
for ( Property property : getProperties() ) {
if ( filter.isEffective( property ) ) {
this.updates.addDelimiter( Constants.SEPARATOR );
this.updates.append( expressionStyle.format( column.apply( property ).alias( parmeterAlias ), property ) );
}
}
if ( updates.isEmpty() ) {
this.updates.append( "(Undefined)" );
}
return updates.toString();
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy