<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<style type="text/css" style="display:none;"> P {margin-top:0;margin-bottom:0;} </style>
</head>
<body dir="ltr">
<div style="color: rgb(0, 0, 0); font-family: Calibri,Helvetica,sans-serif; font-size: 12pt;">
Saludos Joaquín</div>
<div style="color: rgb(0, 0, 0); font-family: Calibri,Helvetica,sans-serif; font-size: 12pt;">
Todo perfecto, muchas gracias<br>
</div>
<div style="color: rgb(0, 0, 0); font-family: Calibri,Helvetica,sans-serif; font-size: 12pt;">
</div>
<hr tabindex="-1" style="width: 98%; display: inline-block;">
<div id="divRplyFwdMsg" dir="ltr"><font color="#000000" face="Calibri, sans-serif" style="font-size: 11pt;"><b>De:</b> gvsig_usuarios-bounces@listserv.gva.es &lt;gvsig_usuarios-bounces@listserv.gva.es&gt; en nombre de Joaquin Jose del Cerro Murciano &lt;jjdelcerro@gvsig.org&gt;<br>
<b>Enviado:</b> jueves, 4 de octubre de 2018 11:22<br>
<b>Para:</b> Lista de Usuarios de gvSIG<br>
<b>Asunto:</b> Re: [Gvsig_usuarios] Problema al actualizar una tabla con scrip</font>
<div>&nbsp;</div>
</div>
<meta content="text/html; charset=utf-8">
<div>
<div dir="ltr">
<div dir="ltr"><br>
<br>
<div class="x_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="x_gmail_quote" style="margin: 0px 0px 0px 0.8ex; padding-left: 1ex; border-left-color: rgb(204, 204, 204); border-left-width: 1px; border-left-style: solid;">
<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;&nbsp;&nbsp;&nbsp; si coge los nuevos datos pero no cierra la edición de la tabla ni guarda los cambios&nbsp;y&nbsp;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>&nbsp;&nbsp;&nbsp; def Okey_click(self,*args):</p>
<p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; NREXISTRO = self.Nentrada.getText()<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; NDATA = self.Dentrada.getText()<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; NVISITA = self.Comprobada.getText()<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; NASINA = self.Dsinatura.getText()<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Nexpedi =&nbsp; self.n_expedi.getText()<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; TablaExpe = currentProject().getTable(&quot;NExpedi&quot;)<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; ndoexpe = TablaExpe().features(&quot;CLAVE_EXPE= '&quot; &#43;Nexpedi &#43;&quot;'&quot; )<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; contarE = ndoexpe.getCount()<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; print contarE<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; if contarE == 0:<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; msgbox(&quot;Non hai este expediente &quot;, &quot;AVISO&quot;, 1)<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; return<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; TablaExpe.edit()<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; for expe in ndoexpe:<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; c = expe.getEditable()<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; c.set(&quot;NREXI&quot;, NREXISTRO)<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; c.set(&quot;DATAREXI&quot;, NDATA)<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; c.set(&quot;DATAVISTA&quot;,NVISITA)<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; c.set(&quot;DATASINA&quot;,NASINA)<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; TablaExpe.update(c)<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; TablaExpe.commit()</p>
<br>
</div>
</div>
</blockquote>
<div>Hola, <br>
pues la respuesta simple seria:<br>
&nbsp; <br>
- Si vas a recorrer una tabla/capa para consultar los datos, puedes hacerlo<br>
&nbsp; 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>
&nbsp; utilizarlo para recorrer los datos y hacer los updates sobre el.<br>
&nbsp; Basicamente, en cuanto hay alguien que esta recorriendo los datos de una tabla,<br>
&nbsp; nadie mas puede hacer updates sobre ella, asi evitamos que puedan haber<br>
&nbsp; modificaciones concurrentes. Los updates solo se pueden hacer sobre el feature<br>
&nbsp; set del que hemos obtenido la feature que queremos actualizar (lo mismo con<br>
&nbsp; inserts y removes).<br>
<br>
Los cambios en el codigo que has incluido deberian ser minimos, algo como:<br>
&nbsp; <br>
&nbsp; TablaExpe.edit()<br>
&nbsp; # Obtenemos un FeatureSet de la tabla<br>
&nbsp; featureSet = TablaExpe.getFeatureStore().getFeatureSet()<br>
&nbsp; for expe in featureSet: # Usamos el FeatureSet para recorrer la tabla<br>
&nbsp;&nbsp;&nbsp; c = expe.getEditable()<br>
&nbsp;&nbsp;&nbsp; c.set(&quot;NREXI&quot;, NREXISTRO)<br>
&nbsp;&nbsp;&nbsp; c.set(&quot;DATAREXI&quot;, NDATA)<br>
&nbsp;&nbsp;&nbsp; c.set(&quot;DATAVISTA&quot;,NVISITA)<br>
&nbsp;&nbsp;&nbsp; c.set(&quot;DATASINA&quot;,NASINA)<br>
&nbsp;&nbsp;&nbsp; featureSet.update(c) # El update lo hacemos sobre el FeatureSet<br>
&nbsp; TablaExpe.commit()<br>
&nbsp; <br>
Un saludo<br>
Joaquin<br>
<br>
</div>
<div><br>
</div>
<div><br>
</div>
<div>&nbsp;</div>
<blockquote class="x_gmail_quote" style="margin: 0px 0px 0px 0.8ex; padding-left: 1ex; border-left-color: rgb(204, 204, 204); border-left-width: 1px; border-left-style: solid;">
<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" target="_blank" rel="noreferrer">https://listserv.gva.es/cgi-bin/mailman/listinfo/gvsig_usuarios</a><br>
</blockquote>
</div>
<br clear="all">
<br>
-- <br>
<div class="x_gmail_signature" dir="ltr">
<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>
</div>
</body>
</html>