次のように、ジオネーム Web サービスを実装しています。
$( "#loc_from" ).autocomplete({
source: function( request, response ) {
$.ajax({
url: "http://ws.geonames.org/searchJSON",
dataType: "jsonp",
data: {
featureClass: "P",
style: "full",
maxRows: 12,
name_startsWith: request.term,
searchlang: 'ES'
},
success: function( data ) {
response( $.map( data.geonames, function( item ) {
item.label = item.name + (item.adminName1 ? ", " + item.adminName1 : "") + ", " + item.countryName;
return item;
}));
}
});
},
minLength: 2,
select: function( event, ui ) {
ui.item.task = 'new_city';
$.post('/includes/router.php', ui.item , function(){
});
$('#id_loc').val(ui.item.gid);
//alert(ui.item.gid);
}
});
router.php の場所:
case 'new_city':
/* comprobar si exite */
$query = "SELECT geonameid FROM geonames";
if(count(cache_query($query))>0){
/* Its already in my database */
}else{
foreach ($_POST as $key => $value) {
check_field($key);
echo $key.': '.$value.'<br>';
}
}
/* si no existe, dar de alta*/
break;
したがって、関数check_field($key)
で geonames.$key フィールドが存在するかどうかを確認し、テーブルを変更して追加したいと思います。
それは可能ですか?(また、これをお勧めしますか?)