diff --git a/web_service/conf/properties.inc b/web_service/conf/properties.inc
index 1860f88996469d2b1e1696ae222a8ec8e1e2655a..30cca53b57a4cd36fe60d5592054d93710d6807f 100755
--- a/web_service/conf/properties.inc
+++ b/web_service/conf/properties.inc
@@ -56,6 +56,9 @@ $properties["cadastre"]["views"]["voie"] = "v_vmap_maj_fv";
 // Tolérence d'intersection (en %)
 $properties["cadastre"]["descr_parcel"]["intersect"]["tolerance"] = 1;
 
+// Si une colonne id_com est définie dans la table intersectée, alors elle sera utilisée en plus de l'intersection spatiale
+$properties["cadastre"]["descr_parcel"]["intersect"]["intersect_id_com"] = true;
+
 
 // On peut donner soit un logo soit un nom de company
 $properties["cadastre"]["fiche_urb"]["logo"] = "";
@@ -94,4 +97,8 @@ $properties["cadastre"]["view"]["bati"] = "s_cadastre.v_vmap_batiment";
 
 // Tolérence d'intersection (en %)
 $properties["cadastre"]["fiche_urb"]["intersect"]["tolerance"] = 1;
+
+// Si une colonne id_com est définie dans la table intersectée, alors elle sera utilisée en plus de l'intersection spatiale
+$properties["cadastre"]["fiche_urb"]["intersect"]["intersect_id_com"] = true;
+
 ?>
diff --git a/web_service/sql/sqlQueries.xml b/web_service/sql/sqlQueries.xml
index a61dcbb2b8e395f05a70745ba1ea29624a20deaa..2249532b0e58eca5f3e319a440fcb3da2a5c91a7 100644
--- a/web_service/sql/sqlQueries.xml
+++ b/web_service/sql/sqlQueries.xml
@@ -1515,7 +1515,7 @@
 					ALTER TABLE ONLY  "s_cadastre"."tc_sym" ADD CONSTRAINT "tc_sym_pkey" PRIMARY KEY ("sym_code");
 					ALTER TABLE ONLY  "s_cadastre"."tc_can" ADD CONSTRAINT "tc_can_pkey" PRIMARY KEY ("can_code");
 					ALTER TABLE ONLY  "s_cadastre"."tc_copl" ADD CONSTRAINT "tc_copl_pkey" PRIMARY KEY ("copl_code");
-					CREATE TABLE "s_cadastre".version ( version character varying(10) NOT NULL, build integer NOT NULL, date timestamp with time zone NOT NULL, active boolean ) WITH (OIDS = FALSE);
+					CREATE TABLE "s_cadastre".version ( version character varying(100) NOT NULL, build integer NOT NULL, date timestamp with time zone NOT NULL, active boolean ) WITH (OIDS = FALSE);
 					ALTER TABLE "s_cadastre".version OWNER TO u_vitis;
 					CREATE TABLE "s_cadastre".batiment (id bigserial NOT NULL,id_com character(5) NOT NULL,dur_code character (2),pre character(3),section character(2), geom public.geometry(MultiPolygon),  CONSTRAINT enforce_srid_geom CHECK (st_srid(geom) = $(SRID))) WITH (OIDS=FALSE);
 					ALTER TABLE "s_cadastre".batiment OWNER TO u_vitis;
diff --git a/web_service/ws/FicheDescriptiveParcelle.class.inc b/web_service/ws/FicheDescriptiveParcelle.class.inc
index 8a6980d116115cbf035d7f9aba300f10cdc08d02..112f1f9a77934a075bb4d683c24946595ec3a882 100755
--- a/web_service/ws/FicheDescriptiveParcelle.class.inc
+++ b/web_service/ws/FicheDescriptiveParcelle.class.inc
@@ -14,7 +14,7 @@ require_once dirname($_SERVER['SCRIPT_FILENAME']) . '/class/vmlib/BdDataAccess.i
  * 	\brief This file contains the FicheDescriptiveParcelle php class
  *
  * This class defines the rest api for fichedescriptiveparcelle
- * 
+ *
  */
 class FicheDescriptiveParcelle extends Cadastre {
     /**
@@ -144,6 +144,7 @@ class FicheDescriptiveParcelle extends Cadastre {
 
         // Infos complémentaires (paramétrées par l'administrateur)
         $iTolerance = $this->aProperties["cadastre"]["descr_parcel"]["intersect"]["tolerance"];
+        $bInterectIdCom = $this->aProperties["cadastre"]["descr_parcel"]["intersect"]["intersect_id_com"];
         $aIntersectionViews = $this->aProperties['cadastre']['descr_parcel']['intersect']['views'];
 
         // Récupère la géométrie de la parcelle
@@ -192,6 +193,17 @@ class FicheDescriptiveParcelle extends Cadastre {
 
             $aIntersect = $this->vmapIntersectGet($sSchema, $sTable, $parcelleGeom, $aAttributs, $iTolerance, $sGeomColumn, $sGeomType);
 
+            // Supprime les intersections qui ne sont pas de le même commune
+            if ($bInterectIdCom == true) {
+                foreach ($aIntersect as $key2 => $value2) {
+                    if (!empty($value2['id_com'])) {
+                        if ($value2['id_com'] != substr($ID_PAR,0,5)) {
+                            unset($aIntersect[$key2]);
+                        }
+                    }
+                }
+            }
+
             $value['data'] = $aIntersect;
             if (isset($value['data'][0]) && !empty($value['data'][0])) {
                 $value['aFields'] = array_keys($value['data'][0]);
@@ -207,4 +219,4 @@ class FicheDescriptiveParcelle extends Cadastre {
 
 }
 
-?>
\ No newline at end of file
+?>
diff --git a/web_service/ws/FicheUrbanisme.class.inc b/web_service/ws/FicheUrbanisme.class.inc
index 841ac4397f85ebb9a366559684b55629e97fbbc1..349698f30d94b32f4f73c3008270217262937af9 100755
--- a/web_service/ws/FicheUrbanisme.class.inc
+++ b/web_service/ws/FicheUrbanisme.class.inc
@@ -132,6 +132,7 @@ class FicheUrbanisme extends Cadastre {
         // Infos complémentaires (paramétrées par l'administrateur)
         $aIntersectionViews = $this->aProperties['cadastre']['fiche_urb']['intersect']['views'];
         $iTolerance = $this->aProperties["cadastre"]["fiche_urb"]["intersect"]["tolerance"];
+        $bInterectIdCom = $this->aProperties["cadastre"]["fiche_urb"]["intersect"]["intersect_id_com"];
         if (is_array($aIntersectionViews)) {
             foreach ($aIntersectionViews as $key => $value) {
                 if (strpos($key, ".") === false) {
@@ -165,6 +166,17 @@ class FicheUrbanisme extends Cadastre {
 
                 $aIntersect = $this->vmapIntersectGet($sSchema, $sTable, $parcelleGeom, $aAttributs, $iTolerance, $sGeomColumn, $sGeomType);
 
+                // Supprime les intersections qui ne sont pas de le même commune
+                if ($bInterectIdCom == true) {
+                    foreach ($aIntersect as $key2 => $value2) {
+                        if (!empty($value2['id_com'])) {
+                            if ($value2['id_com'] != substr($ID_PAR,0,5)) {
+                                unset($aIntersect[$key2]);
+                            }
+                        }
+                    }
+                }
+
                 $value['data'] = $aIntersect;
                 $value['attributs'] = $aOrderedKeys;