當前位置: 首頁>>代碼示例>>Java>>正文


Java BatchUpdateException.getNextException方法代碼示例

本文整理匯總了Java中java.sql.BatchUpdateException.getNextException方法的典型用法代碼示例。如果您正苦於以下問題:Java BatchUpdateException.getNextException方法的具體用法?Java BatchUpdateException.getNextException怎麽用?Java BatchUpdateException.getNextException使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在java.sql.BatchUpdateException的用法示例。


在下文中一共展示了BatchUpdateException.getNextException方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: tratarHibernatePostgreSQL

import java.sql.BatchUpdateException; //導入方法依賴的package包/類
@ExceptionHandler
public void tratarHibernatePostgreSQL(RollbackException e) {
	PersistenceException persistenceException = (PersistenceException) e
			.getCause();
	/*
	 * Desde aquí ya no es estándar JEE6, estas son clases específicas de
	 * Hibernate y PostgreSQL dependiendo del proveedor JPA y del motor que
	 * se utilice esto habrá que adaptar
	 */
	ConstraintViolationException constraintViolationException = (ConstraintViolationException) persistenceException
			.getCause();
	BatchUpdateException batchUpdateException = (BatchUpdateException) constraintViolationException
			.getCause();
	Exception psqlException = batchUpdateException.getNextException();
	String msg = psqlException.getLocalizedMessage();
	logger.error("Error al realizar el update: " + msg);
	FacesContext.getCurrentInstance().addMessage(null,
			new FacesMessage(FacesMessage.SEVERITY_ERROR, msg, null));
}
 
開發者ID:alefq,項目名稱:tekoporu-postgresql,代碼行數:20,代碼來源:UsuarioEditMB.java

示例2: insert

import java.sql.BatchUpdateException; //導入方法依賴的package包/類
public void insert() throws SQLException {
	try {
		statement.executeBatch();
	}
	catch (BatchUpdateException e) {
		throw e.getNextException();
	}
	finally {
		statement.close();
	}
}
 
開發者ID:quantumdb,項目名稱:quantumdb,代碼行數:12,代碼來源:BatchInserter.java

示例3: getUnderlyingSQLException

import java.sql.BatchUpdateException; //導入方法依賴的package包/類
/**
 * This method will take care of finding the real underlying exception. When a jdbc or hibernate
 * exception occurs then the whole stack trace is not available in the log because the exception
 * does not return the underlying exception using the {@link Throwable#getCause()} but using the
 * {@link SQLException#getNextException()}.
 * 
 * @param throwable
 *          the throwable to analyze
 * @return the underlying sql exception or the original throwable if none found
 */
public static Throwable getUnderlyingSQLException(Throwable throwable) {

  if (throwable instanceof BatchUpdateException
      && ((BatchUpdateException) throwable).getNextException() != null) {
    return ((BatchUpdateException) throwable).getNextException();
  }
  if (throwable.getCause() instanceof BatchUpdateException
      && ((BatchUpdateException) throwable.getCause()).getNextException() != null) {
    final BatchUpdateException bue = (BatchUpdateException) throwable.getCause();
    return bue.getNextException();
  }
  if (throwable.getCause() instanceof org.hibernate.exception.GenericJDBCException
      && ((org.hibernate.exception.GenericJDBCException) throwable.getCause()).getSQLException()
          .getNextException() != null) {
    final org.hibernate.exception.GenericJDBCException gjdbce = (org.hibernate.exception.GenericJDBCException) throwable
        .getCause();
    return gjdbce.getSQLException().getNextException();
  }
  if (throwable.getCause() instanceof org.hibernate.exception.ConstraintViolationException
      && ((org.hibernate.exception.ConstraintViolationException) throwable.getCause())
          .getSQLException().getNextException() != null) {
    final org.hibernate.exception.ConstraintViolationException cve = (org.hibernate.exception.ConstraintViolationException) throwable
        .getCause();
    return cve.getSQLException().getNextException();
  }
  return throwable;
}
 
開發者ID:mauyr,項目名稱:openbravo-brazil,代碼行數:38,代碼來源:DbUtility.java

示例4: hibernateData

import java.sql.BatchUpdateException; //導入方法依賴的package包/類
/**
 * Hibernate data.
 *
 * @param article
 *            the article
 * @param session
 *            the session
 * @return true, if successful
 */
public synchronized boolean hibernateData(final NewsArticle article, final Session session) {
	Transaction tx = null;

	HibernateHelper.logger.debug("hibernateData: " + article.getArticleId());

	final Location location = null;
	final String gender = null;
	try {
		tx = session.beginTransaction();
		tx.begin();

		final UsenetUser poster = this.createUsenetUser(article, session, location, gender);

		final Message message = this.createMessage(article, null, poster);

		this.storeNewsgroups(article.getNewsgroupsList(), message, session);

		tx.commit();

	}
	catch (Exception e) {
		if (e instanceof GenericJDBCException) {
			e = (Exception) e.getCause();
		}
		if (e instanceof BatchUpdateException) {
			final BatchUpdateException buex = (BatchUpdateException) e;
			System.err.println("Contents of BatchUpdateException:");
			System.err.println(" Update counts: ");
			final int[] updateCounts = buex.getUpdateCounts();
			for (int i = 0; i < updateCounts.length; i++) {
				System.err.println("  Statement " + i + ":" + updateCounts[i]);
			}
			System.err.println(" Message: " + buex.getMessage());
			System.err.println(" SQLSTATE: " + buex.getSQLState());
			System.err.println(" Error code: " + buex.getErrorCode());
			System.err.println(" Article: " + article);

			SQLException ex = buex.getNextException();
			while (ex != null) {
				System.err.println("SQL exception:");
				System.err.println(" Message: " + ex.getMessage());
				System.err.println(" SQLSTATE: " + ex.getSQLState());
				System.err.println(" Error code: " + ex.getErrorCode());
				System.err.println(" Error code: " + ex.getErrorCode());

				ex = ex.getNextException();
			}

		}
		HibernateHelper.logger.error("Failed to store message", e);
		e.printStackTrace();
		if (tx != null) {
			try {
				tx.rollback();
			}
			catch (final HibernateException e1) {
				e1.printStackTrace();
				return false;
			}
		}
	}
	return true;
}
 
開發者ID:leonarduk,項目名稱:unison,代碼行數:73,代碼來源:HibernateHelper.java


注:本文中的java.sql.BatchUpdateException.getNextException方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。