com.mongodb.MongoBulkWriteException Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of mongodb-driver-core Show documentation
Show all versions of mongodb-driver-core Show documentation
The Java operations layer for the MongoDB Java Driver. Third parties can ' +
'wrap this layer to provide custom higher-level APIs
/*
* Copyright 2008-present MongoDB, Inc.
*
* 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.mongodb;
import com.mongodb.bulk.BulkWriteError;
import com.mongodb.bulk.BulkWriteResult;
import com.mongodb.bulk.WriteConcernError;
import com.mongodb.lang.Nullable;
import java.util.Collections;
import java.util.List;
import java.util.Objects;
import java.util.Set;
/**
* An exception that represents all errors associated with a bulk write operation.
*
* @since 3.0
* @serial exclude
*/
public class MongoBulkWriteException extends MongoServerException {
private static final long serialVersionUID = -4345399805987210275L;
private final BulkWriteResult writeResult;
private final List errors;
private final ServerAddress serverAddress;
private final WriteConcernError writeConcernError;
/**
* Constructs a new instance.
*
* @param writeResult the write result
* @param writeErrors the list of errors
* @param writeConcernError the write concern error
* @param serverAddress the server address.
*
* @deprecated Prefer {@link MongoBulkWriteException#MongoBulkWriteException(BulkWriteResult, List, WriteConcernError,
* ServerAddress, Set)} instead
*/
@Deprecated
public MongoBulkWriteException(final BulkWriteResult writeResult, final List writeErrors,
@Nullable final WriteConcernError writeConcernError, final ServerAddress serverAddress) {
this(writeResult, writeErrors, writeConcernError, serverAddress, Collections.emptySet());
}
/**
* Constructs a new instance.
*
* @param writeResult the write result
* @param writeErrors the list of errors
* @param writeConcernError the write concern error
* @param serverAddress the server address.
* @param errorLabels any server errorLabels
* @since 4.1
*/
@SuppressWarnings("deprecation")
public MongoBulkWriteException(final BulkWriteResult writeResult, final List writeErrors,
@Nullable final WriteConcernError writeConcernError, final ServerAddress serverAddress,
final Set errorLabels) {
super("Bulk write operation error on server " + serverAddress + ". "
+ (writeErrors.isEmpty() ? "" : "Write errors: " + writeErrors + ". ")
+ (writeConcernError == null ? "" : "Write concern error: " + writeConcernError + ". "), serverAddress);
this.writeResult = writeResult;
this.errors = writeErrors;
this.writeConcernError = writeConcernError;
this.serverAddress = serverAddress;
addLabels(errorLabels);
if (writeConcernError != null) {
addLabels(writeConcernError.getErrorLabels());
}
}
/**
* The result of all successfully processed write operations. This will never be null.
*
* @return the bulk write result
*/
public BulkWriteResult getWriteResult() {
return writeResult;
}
/**
* The list of errors, which will not be null, but may be empty (if the write concern error is not null).
*
* @return the list of errors
*/
public List getWriteErrors() {
return errors;
}
/**
* The write concern error, which may be null (in which case the list of errors will not be empty).
*
* @return the write concern error
*/
@Nullable
public WriteConcernError getWriteConcernError() {
return writeConcernError;
}
/**
* The address of the server which performed the bulk write operation.
*
* @return the address
*/
public ServerAddress getServerAddress() {
return serverAddress;
}
@Override
public boolean equals(final Object o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
MongoBulkWriteException that = (MongoBulkWriteException) o;
if (!errors.equals(that.errors)) {
return false;
}
if (!serverAddress.equals(that.serverAddress)) {
return false;
}
if (!Objects.equals(writeConcernError, that.writeConcernError)) {
return false;
}
if (!writeResult.equals(that.writeResult)) {
return false;
}
return true;
}
@Override
public int hashCode() {
int result = writeResult.hashCode();
result = 31 * result + errors.hashCode();
result = 31 * result + serverAddress.hashCode();
result = 31 * result + (writeConcernError != null ? writeConcernError.hashCode() : 0);
return result;
}
}