Forループを使用してテーブルからすべての行を返します。それは各行を適切に通過しますが、次の行に移動しても同じ値を返し続けます。以下はForループは同じ値を返し続けます
コード:
function setLayer($result_set, $row){
$str = "MyMap_".mb_convert_encoding(mssql_result($result_set, $i, 0),"UTF-8","SJIS")."_".mb_convert_encoding(mssql_result($result_set, $i, 1),"UTF-8","SJIS");
return "".$str." = new OpenLayers.Layer.WMS(\"".$str."\",\"http://192.168.0.69/cgi-bin/mapserv.exe?map=C:/ms4w/Apache/htdocs/mapserver/data/toyama/toyama_mymap.map&service=WMS&SRS=EPSG:2449&VERSION=1.1.1&format=image/PNG&layers=".$str."\", {'layers': '".$str."'}, {isBaseLayer: false, visibility: false,opacity:0.5,alpha:true});
map.addLayer(".$str.");\n\n";
}
ループ:
for($i=0; $i<=$group_layer_row; $i++){
echo setLayer($rs_group_layer, $i);
}
私の推論は、ループがすべての行を通過するものの、それは与え続けるので、$ strのは、別の行を反映するように変更しないことです行の値が異なっていても同じ値です。閉じる?
誰かがこれを手伝ってくれることを願っています。ありがとうございました。
ありがとうございました。遅く返答して申し訳ありませんが、サーバーはダウンしていますので、今までこの変更を実装できませんでした。ループは現在、行ごとに適切な値を返しています。別のエラーが発生しましたが、それはSQLのための別の質問ですので、新しい質問をしています。ご協力いただきありがとうございます。 – Yus