<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40"><head><meta http-equiv=Content-Type content="text/html; charset=iso-8859-1"><meta name=Generator content="Microsoft Word 14 (filtered medium)"><style><!--
/* Font Definitions */
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0cm;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri","sans-serif";
        mso-fareast-language:EN-US;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:blue;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:purple;
        text-decoration:underline;}
span.EstiloCorreo17
        {mso-style-type:personal-compose;
        font-family:"Calibri","sans-serif";
        color:windowtext;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-family:"Calibri","sans-serif";
        mso-fareast-language:EN-US;}
@page WordSection1
        {size:612.0pt 792.0pt;
        margin:70.85pt 3.0cm 70.85pt 3.0cm;}
div.WordSection1
        {page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]--></head><body lang=ES link=blue vlink=purple><div class=WordSection1><p class=MsoNormal>Hola a todos,<o:p></o:p></p><p class=MsoNormal> estamos trabajando en un plugin para QGis en python.<o:p></o:p></p><p class=MsoNormal>El objetivo es cargar capas de postgis 2.x  a partir de varios criterios de selección, el problema se nos presenta cuando vamos a cargar una vista creada por nosotros , les muestro un ejemplo de creación :<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><span lang=EN-US>CREATE OR REPLACE VIEW vcaminos AS <o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US> </span>SELECT e.codcamino, e.codprovinc, e.codmunicip, e.desde, e.hasta, e.longitud, <o:p></o:p></p><p class=MsoNormal>    e.nombrecomu, e.poseedor, e.ancho, e.tienecunet, e.estadocune, e.no_carril, <o:p></o:p></p><p class=MsoNormal>    e.nombre, e.estadocami, e.gid, <o:p></o:p></p><p class=MsoNormal>    <span lang=EN-US>st_intersection(st_setsrid(st_envelope('0104000000020000000101000000F8C2642AA5650841DBF97EEA60DC12410101000000B22E6EA33C320C411D3867445C061141'::geometry), 2085), st_setsrid(e.the_geom, 2085))::geometry(LineString,2085) AS the_geom<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US>   FROM caminos e<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US>  WHERE NOT st_isempty(st_intersection(st_setsrid(st_envelope('0104000000020000000101000000F8C2642AA5650841DBF97EEA60DC12410101000000B22E6EA33C320C411D3867445C061141'::geometry), 2085), st_setsrid(e.the_geom, 2085)));<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US><o:p> </o:p></span></p><p class=MsoNormal><span lang=EN-US>ALTER TABLE vcaminos<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US>  OWNER TO postgres;<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US><o:p> </o:p></span></p><p class=MsoNormal><span lang=EN-US><o:p> </o:p></span></p><p class=MsoNormal>El problema está cuando tratamos de cargar la vista al mapa usando nuestro código , nos dice “ La capa PostgreSQL no tiene clave primaria.”. , sin embargo si la adicionamos por la herramienta de QGis , vemos que esta llave está definida y es gid , y si se adiciona  bien al mapa.<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Mi pregunta es , ¿ el problema está en la definición de la vista ?, alguien puede orientarme al respecto<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Fragmento del código que adiciona la vista al mapa :<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>self.Datos = self.conexion.limitar_vista(esquema,tabla,xSupIzq,ySupIzq,xInfDer,yInfDer)<o:p></o:p></p><p class=MsoNormal><span lang=EN-US>if self.Datos:<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US>                print self.Datos[0]<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US>                uri = QgsDataSourceURI()<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US>                uri.setConnection(self.server, str(self.port), self.bd, self.user, self.password)<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US>                </span>#aDatos = [str(esquema), str(nombre_vista), geometry_col, tipo_tabla]<o:p></o:p></p><p class=MsoNormal>                uri.setDataSource(self.Datos[0][0], self.Datos[0][1], self.Datos[0][2])<o:p></o:p></p><p class=MsoNormal>                name_capa = self.Datos[0][1].capitalize()<o:p></o:p></p><p class=MsoNormal>                <span lang=EN-US>layer = QgsVectorLayer(uri.uri(), name_capa, "postgres")<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US>                if layer.isValid():<o:p></o:p></span></p><p class=MsoNormal><span lang=EN-US>                               <b>QgsMapLayerRegistry.instance().addMapLayer(<o:p></o:p></b></span></p><p class=MsoNormal><b><span lang=EN-US>                                               layer);<o:p></o:p></span></b></p><p class=MsoNormal><span lang=EN-US>                               self.clickTool.cargoOK()<o:p></o:p></span></p><p class=MsoNormal>else:<o:p></o:p></p><p class=MsoNormal>                self.clickTool.noData()<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal>Saludos<o:p></o:p></p><p class=MsoNormal>Francisco Salas<o:p></o:p></p><p class=MsoNormal><o:p> </o:p></p></div>
<br><pre>----------------------------------------------------------------------------------------------------
¿Dónde estoy? ¿Qué hay a mí alrededor? ¿A dónde quiero ir? ¿Dónde está lo que busco? ¿Cómo llegar? ¿Cómo anunciar mi negocio?……
Si quiere solucionar todo esto visite y descargue la nueva aplicación móvil disponible en http://andariego.geocuba.cu

</pre><br></body></html>