簡體   English   中英

多次查詢Postgres數據庫以獲取Choropleth Leaflet map

[英]Multiple queries to Postgres database for choropleth Leaflet map

我正在使用nodejs Postgres和Leaflet創建一個Choroplethic映射。 我有一個查詢正在地圖上運行並完美運行。 但是,我似乎無法再進行其他工作,因為我希望這些成為用戶可以選擇的選項。 這是我的代碼。 順便說一下,我真的很陌生。

  // Set up database query to display GeoJSON
  var OSM = "SELECT row_to_json(fc) FROM (SELECT 'FeatureCollection' As      type, array_to_json(array_agg(f)) As features FROM (SELECT 'Feature' As type,     ST_AsGeoJSON(lg.geom)::json As geometry, row_to_json((thirty_cens, name_tag)) As properties FROM civil_parishes As lg) As f) As fc";
 //var OSM2 ="SELECT row_to_json(fc) FROM (SELECT 'FeatureCollection' As type, array_to_json(array_agg(f)) As features FROM (SELECT 'Feature' As type, ST_AsGeoJSON(lg.geom)::json As geometry, row_to_json((twenty_cens, name_tag)) As properties FROM civil_parishes As lg) As f) As fc";
 /* GET home page. */
 router.get('/', function(req, res) {
   res.render('index', {
      title: 'Web Mapping'
    });
});

module.exports = router;

/* GET Postgres JSON data */
router.get('/data', function (req, res) {
    var client = new pg.Client(conString);
    client.connect();
    var query = client.query(OSM);
      query.on("row", function (row, result) {
       result.addRow(row);
     });
      query.on("end", function (result) {
        res.send(result.rows[0].row_to_json);
        res.end();
     });
  });

 /* GET the map page */
 router.get('/map', function(req, res) {
    var client = new pg.Client(conString);  // Setup Postgres Client
    client.connect();                       // connect to the client
    var query = client.query(OSM);          // Run Query
     query.on("row", function (row, result) {
       result.addRow(row);
       });
  // Pass the result to the map page
   query.on("end", function (result) {
       var data = result.rows[0].row_to_json // Save the JSON as variable data
       res.render('map', {
          title: "Web Mapping",              // Give a title to page
          jsonData: data                    // Pass data to the View
      });
   })
 });

這是我的map.jade頁面:

#map(style='height: 100%; width: 100%')
    script(src='http://cdn.leafletjs.com/leaflet/v0.7.7/leaflet.js')
script(src='http://code.jquery.com/jquery-2.1.0.min.js')
script.
    var myData = !{JSON.stringify(jsonData)};// Create variable to hold map element, give initial settings to map
    //var myData2 = !{JSON.stringify(jsonData2)};// Create variable to hold map element, give initial settings to map
    var map = L.map('map').setView([53.2734, -7.778320310000026], 7);
    var osmmap = L.tileLayer('http://{s}.tile.osm.org/{z}/{x}/{y}.png', {attribution: '&copy; <a href="http://osm.org/copyright">OpenStreetMap</a> contributors'}).addTo(map);
    // Add JSON to map
    var censLayer=new L.geoJson(myData,{
        style:getStyle,
        onEachFeature: onEachFeature
        });
    //var censLayer2=new L.geoJson(myData2,{
        //style:getStyle,
        //onEachFeature: onEachFeature
        /});
    function getStyle(feature) {
        return {
            weight: 1,
            opacity: 1,
            color: '#fff',
            fillOpacity: 0.7,
            fillColor: getColor(feature.properties.f1)
        };
    }
    function getColor(d) {
        return d > 100  ? 'blue' :
                d > 70 ? 'red' :
                d > 50  ? 'green' :
                        'grey';
                }
    function onEachFeature(feature, layer){
        layer.bindPopup(feature.properties.f2);
    }
    var baseMaps ={
        "osmmap": osmmap};
    var overlayMaps = {
        "censLayer": censLayer};
    L.control.layers(baseMaps,overlayMaps).addTo(map);

我知道運行OSM2查詢並將其鏈接到cwnsLayer2不起作用。 誰能提供任何關於為什么它不起作用的建議?

免責聲明我對此也很陌生,這恰好起作用。 可能不是最佳解決方案。

我遇到同樣的問題,因為我無法使多個查詢工作。 問完之后,這是我想出的解決方案:

router.get('/map', function(req, res) {
     var client = new pg.Client(conString);  
     client.connect();

     var dataHolder = []; //use this to store you results to JSON

     var query = client.query(OSM);          
     query.on("row", function (row, result) {
          result.addRow(row);
  });

     query.on("end", function (result) {
         var data = result.rows[0].row_to_json;

         dataHolder.push(data) // add this


         // this will run your second query
         var query = client.query(OSM2);          
         query.on("row", function (row, result) {
            result.addRow(row);
         });

         query.on("end", function (result) {
             var data2 = result.rows[0].row_to_json;

             dataHolder.push(data2) // add this

             res.render('map', {
                title: "Web Mapping",              
                jsonData: data[0]
                jsonData2: data[1]
            });                    
         });
     })
 });

如果您遇到更好的解決方案,請分享:D

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM