2016-04-08 21 views
0

aracılığıyla güncelleyerek güncelleştirme FusionTables uygulamasındaki beş sütunun dördünü, Google E-tablosundaki verileri kullanarak güncellemeye çalışıyorum. Apps-script'lerini programlamaya yeni başladım. Güncelleme sorgusunda yardıma ihtiyacım var. Herhangi bir öneri veya geribildirim takdir edilmektedir. Şimdiden teşekkür ederim.Google FusionTables uygulamasını elektronik ortamda

function sync() { 
    var tasks = FusionTables.Task.list(TABLE_ID); 
    // Only run if there are no outstanding deletions or schema changes. 
    if (tasks.totalItems === 0) { 
     var sheet = SpreadsheetApp.getActiveSheet(); 
     var data = sheet.getDataRange().getValues(); 
     //i = 1 for 1st row with values in spreadsheet. 0 for column headers. 
     for (var i = 1; i < data.length; i++) { 
      var cName = data[i][0]; 
      var ed_vs = data[i][1]; 
      var ed_vs_ada = data[i][2]; 
      var color = data[i][3];  
      //update ft 
      var updateQry = "update "+TABLE_ID+" set ED_VS = "+ed_vs+",ED_VS_ADA = "+ed_vs_ada+", COLOR = "+color+ "where COUNTY = "+cName; 
      //FusionTables.Query.sql(updateQry); 
      //is this even possible to execute an update query? help with syntax? 
      Logger.log(updateQry); 
     } 
    } 
}; 
+0

Yardıma ihtiyacınız olan kısım nerede? – SwagBomb

+0

//FusionTables.Query.sql(updateQry); Güncelleme sorgusunu yürütmede yardıma ihtiyacım var. – user3393629

+0

güncelleme: sözdizimi doğru görünüyor ancak sorun sql sorgusunda. ROWID 'i kullanmak yerine' ilçe 'yerine kullanmak zorundayım. – user3393629

cevap

0

İşte benzer bir sorunu olan birisi için çalışma çözümü.

function sync() { 
    var tasks = FusionTables.Task.list(TABLE_ID); 
    // Only run if there are no outstanding deletions or schema changes. 
    if (tasks.totalItems === 0) { 
    var sheet = SpreadsheetApp.getActiveSheet(); 
    var data = sheet.getDataRange().getValues(); 
    //i = 1 for 1st row with values in spreadsheet. 0 will give column headers. 
    for (var i = 1; i < data.length; i++) { 
     var cName = data[i][0]; 
     var ed_vs = data[i][1]; 
     var ed_vs_ada = data[i][2]; 
     var color = data[i][3]; 

     //parse rowid from output 
     var selQry = "select ROWID FROM "+TABLE_ID+" where COUNTY = '"+cName+"' "; 
     var cdata = FusionTables.Query.sql(selQry); 
     var c_rowid = cdata.rows[0][0]; //rowid 
     Logger.log(c_rowid); 

     var updateQry = "update "+TABLE_ID+" set ED_VS = '"+ed_vs+"',ED_VS_ADA = '"+ed_vs_ada+"', COLOR = '"+color+ "' where ROWID = '"+c_rowid+"' "; 

     FusionTables.Query.sql(updateQry); 

     Logger.log(updateQry);   
    } 
    } 
}; 
İlgili konular