<div dir="ltr"><div dir="ltr"><br><br><div class="gmail_quote"><div dir="ltr">El jue., 4 oct. 2018 a las 9:52, Ovidio Ribeira (&lt;<a href="mailto:alboredos@hotmail.es">alboredos@hotmail.es</a>&gt;) escribió:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">




<div dir="ltr">
<div style="color:rgb(0,0,0);font-family:Calibri,Helvetica,sans-serif;font-size:12pt">
Buenos días, tengo el siguiente script para actualizar una tabla desde un formulario, pero me da el siguiente error &quot; Concurrente modification in store&quot;    si coge los nuevos datos pero no cierra la edición de la tabla ni guarda los cambios y no consigo saber
 cual es el problema,</div>
<div style="color:rgb(0,0,0);font-family:Calibri,Helvetica,sans-serif;font-size:12pt">
Gracias y saludos</div>
<div style="color:rgb(0,0,0);font-family:Calibri,Helvetica,sans-serif;font-size:12pt">
Ovidio</div>
<div style="color:rgb(0,0,0);font-family:Calibri,Helvetica,sans-serif;font-size:12pt">
<p>    def Okey_click(self,*args):</p>
<p>      NREXISTRO = self.Nentrada.getText()<br>
      NDATA = self.Dentrada.getText()<br>
      NVISITA = self.Comprobada.getText()<br>
      NASINA = self.Dsinatura.getText()<br>
      Nexpedi =  self.n_expedi.getText()<br>
      TablaExpe = currentProject().getTable(&quot;NExpedi&quot;)<br>
      ndoexpe = TablaExpe().features(&quot;CLAVE_EXPE= &#39;&quot; +Nexpedi +&quot;&#39;&quot; )<br>
      contarE = ndoexpe.getCount()<br>
      print contarE<br>
      if contarE == 0:<br>
        msgbox(&quot;Non hai este expediente &quot;, &quot;AVISO&quot;, 1)<br>
        return<br>
      TablaExpe.edit()<br>
      for expe in ndoexpe:<br>
        c = expe.getEditable()<br>
        c.set(&quot;NREXI&quot;, NREXISTRO)<br>
        c.set(&quot;DATAREXI&quot;, NDATA)<br>
        c.set(&quot;DATAVISTA&quot;,NVISITA)<br>
        c.set(&quot;DATASINA&quot;,NASINA)<br>
        TablaExpe.update(c)<br>
      TablaExpe.commit()</p>
<br></div></div></blockquote><div>Hola, <br>pues la respuesta simple seria:<br>  <br>- Si vas a recorrer una tabla/capa para consultar los datos, puedes hacerlo<br>  tal como lo has hecho. Pero solo para consultar.<br><br>- Si vas a actualizar los datos de una tabla, debes obtener un feature-set, y <br>  utilizarlo para recorrer los datos y hacer los updates sobre el.<br>  Basicamente, en cuanto hay alguien que esta recorriendo los datos de una tabla,<br>  nadie mas puede hacer updates sobre ella, asi evitamos que puedan haber<br>  modificaciones concurrentes. Los updates solo se pueden hacer sobre el feature<br>  set del que hemos obtenido la feature que queremos actualizar (lo mismo con<br>  inserts y removes).<br><br>Los cambios en el codigo que has incluido deberian ser minimos, algo como:<br>  <br>  TablaExpe.edit()<br>  # Obtenemos un FeatureSet de la tabla<br>  featureSet = TablaExpe.getFeatureStore().getFeatureSet()<br>  for expe in featureSet: # Usamos el FeatureSet para recorrer la tabla<br>    c = expe.getEditable()<br>    c.set(&quot;NREXI&quot;, NREXISTRO)<br>    c.set(&quot;DATAREXI&quot;, NDATA)<br>    c.set(&quot;DATAVISTA&quot;,NVISITA)<br>    c.set(&quot;DATASINA&quot;,NASINA)<br>    featureSet.update(c) # El update lo hacemos sobre el FeatureSet<br>  TablaExpe.commit()<br>  <br>Un saludo<br>Joaquin<br><br></div><div><br></div><div><br></div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div style="color:rgb(0,0,0);font-family:Calibri,Helvetica,sans-serif;font-size:12pt">
</div>
</div>

_______________________________________________<br>
gvSIG_usuarios mailing list<br>
<a href="mailto:gvSIG_usuarios@listserv.gva.es" target="_blank">gvSIG_usuarios@listserv.gva.es</a><br>
<br>
Para ver histórico de mensajes, editar sus preferencias de usuario o darse de baja en esta lista, acuda a la siguiente dirección:<br>
<br>
<a href="https://listserv.gva.es/cgi-bin/mailman/listinfo/gvsig_usuarios" rel="noreferrer" target="_blank">https://listserv.gva.es/cgi-bin/mailman/listinfo/gvsig_usuarios</a><br>
</blockquote></div><br clear="all"><br>-- <br><div dir="ltr" class="gmail_signature"><div dir="ltr"><div><div dir="ltr"><div>--------------------------------------<br>Joaquin Jose del Cerro Murciano<br>Development and software arquitecture manager at gvSIG Team<br><a href="mailto:jjdelcerro@gvsig.com" target="_blank">jjdelcerro@gvsig.com</a><br>gvSIG Association<br><a href="http://www.gvsig.com" target="_blank">www.gvsig.com</a><br></div></div></div></div></div></div></div>