Skip to main content

Solucionar el problema conflictos al sincronizar: 1 SyncResolver.UPDATE_ROW_CONFLICT

Cuando deseamos actualizar algunos campos de una tabla y no todos, a veces nos encontramos con el mensaje de error:
  • No se pueden guardar los cambios -- java.lang.RuntimeException: Número de conflictos al sincronizar: 1 SyncResolver.UPDATE_ROW_CONFLICT fila 4 intento de actualizar una fila que otro usuario ha actualizado o eliminado
Una forma sencilla de evitarlo es definir en el select del metodo _init() solo aquellos campos de la tabla que vamos a actualizar. Supomenos que solo deseamos actualizar los campos foto1 a foto8 y el idhabitacion lo hariamos de esta manera y eliminamos los demas campos del select.

private void _init() throws Exception {
habitacionesRowSet.setDataSourceName("java:comp/env/jdbc/hoteles");
habitacionesRowSet.setCommand("SELECT idhabitacion,foto1,foto2,foto3,foto4,foto5,foto6,foto7,foto8 FROM habitaciones");
habitacionesRowSet.setTableName("habitaciones");
habitacionesDataProvider.setCachedRowSet((javax.sql.rowset.CachedRowSet)getValue("#{habitacionesAgregarFotos.habitacionesRowSet}"));
}


El metodo init quedaria asi:
public void init() {
// Realizar iniciaciones heredadas de la superclase
super.init();
// Realizar inicio de aplicación que debe finalizar
// *antes* de que se inicien los componentes administrados
// TODO - Agregar código de inicio propio aquí

//
// Iniciar componentes administrados automáticamente
// *Nota* - esta lógica NO debe modificarse
try {
_init();
} catch (Exception e) {
log("habitacionesAgregarFotos Initialization Failure", e);
throw e instanceof FacesException ? (FacesException) e: new FacesException(e);
}
//

// Realizar inicio de aplicación que debe finalizar
// *después* de que se inicien los componentes administrados
// TODO - Agregar código de inicio propio aquí
String idHabitacion = getSessionBean1().getIdHabitacion();
RowKey habitacionesRowKey = habitacionesDataProvider.findFirst("habitaciones.idhabitacion", idHabitacion);
habitacionesDataProvider.setCursorRow(habitacionesRowKey);
habitacionesDataProvider.refresh();
}


y el evento guardar
public String guardarButton_action() {
// TODO: Procesar la acción de clic de botón. El valor de devolución es un
// nombre de caso de navegación en el que un valor nulo devolverá la misma página.
try {
habitacionesDataProvider.commitChanges();
habitacionesDataProvider.refresh();
info("Se guardaron los cambios....");
this.guardarButton.setDisabled(true);
} catch (Exception e) {
error("No se pueden guardar los cambios -- " + e);
log("Exception: " + e);
}
return null;
}









Comments

Anonymous said…
Muchas gracias por la información, pero yo tengo este problema la cuestión es que no me puedo librar de los campos "extras" porque los necesito para otras operaciones. Así que alguien tiene alguna otra posible solución para este problema. Gracias.
LAF said…
Muchas gracias por la información, pero yo tengo este problema la cuestión es que no me puedo librar de los campos "extras" porque los necesito para otras operaciones. Así que alguien tiene alguna otra posible solución para este problema. Gracias.

Popular posts from this blog

Apache NetBeans

Apache NetBeans
https://wiki.apache.org/incubator/NetBeansProposal

Si, algo que se esperaba desde hace muchos años, una liberación de NetBeans, para convertirlo en un IDE más abierto, y que permita mayor contribución de la comunidad y de otras empresas, ya inicio su primera etapa en la incubadora de la Fundación Apache.
Las implicaciones que esto conlleva son múltiples por una parte esta la evolución de NetBeans, al permitir que más contribuyentes puedan aportar a sus mejoras, también garantiza que aquellas instituciones no sientan que es una sola organización la que controla la evolución. A las comunidades les permite sentirse que participan de un proyecto con todas las garantías que ofrece la Fundación Apache.

Muchos pensaran que Oracle esta dejando morir el proyecto, la realidad es diferente, hay muchos ingenieros que están participando del proyecto en la fundación Apache.
Es una noticia excelente para los desarrolladores, instituciones, empresas que utilizan NetBeans , se estima qu…

Un ejemplo sencillo de Refactorización y Genericos

Un ejemplo sencillo de Refactorización y Genericos

public class Refactorizador<K, V> {

    public V copyFromBeans(K k, V v) {
        try {
            Class claseK = k.getClass();
            Class claseV = v.getClass();

            Method[] metodosK = claseK.getMethods();

            for (Method method : metodosK) {
                if (isGetter(method)) {
                    Method metodoGetK = claseK.getDeclaredMethod(method.getName());
                    Method metodoSetV = claseV.getDeclaredMethod(changeGetBySet(method.getName()), method.getReturnType());
                    metodoSetV.invoke(v, metodoGetK.invoke(k));
                }

            }

        } catch (Exception e) {
            System.out.println("refactorizador() " + e.getLocalizedMessage());
        }
        return v;
    }

     public  boolean isGetter(Method method) {

        if (!method.getName().startsWith("get")) {
            return false;
        }
        if (method.getName().startsWith("getCla…

FileUpload con Primefaces

FileUpload con Primefaces

Si queremos subir imagenes a nuestra aplicación usaremos el componente FileUpload Debemos realizar los siguientes pasos:
Agregar al archivo web.xml

   <filter>        <filter-name>PrimeFaces FileUpload Filter</filter-name>        <filter-class>            org.primefaces.webapp.filter.FileUploadFilter        </filter-class>    </filter>    <filter-mapping>        <filter-name>PrimeFaces FileUpload Filter</filter-name>        <servlet-name>Faces Servlet</servlet-name>    </filter-mapping>



Crear dentro de resources el directorio donde deseamos almacenar las imagenes En este ejemplo: resources/fotos/clinicas y agregue una imagen llamada fotos.png que se usará como imagen inicial.



En JSFUtil u otro @Named Beans que usemos agregamos tres métodos uno para obtener el path de la aplicación web , otro para obtener el path relativo a /fotos/clinicas y el otro para copiar los archivos. /*