フィールドの配列があり、implode
関数を使用してそれらを文字列に変換した後、次のように関数の列の名前としてこの文字列を使用しようとしてmysql_query()
います:
$field_array = array('course','batch','branch');
$fields = implode(", ",$field_array);
$resource = mysql_query("SELECT $fields FROM some_table") or die(mysql_error());
しかし、私は次のエラーが発生しています。ここで私が間違っていることは何ですか?
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'FROM fix_data' at line 1
以下は私が使用している正確なコードです
function fetch_resource_db_nowhere($table_name,$field_array,$return_type,$return_type_name) {
if($field_array[0]=='ALL') {
//echo "asda";
$resource = mysql_query("SELECT * FROM ".$table_name."") or die(mysql_error());
}
else {
$fields = implode(",",$field_array);
$sql = "SELECT ".$fields." FROM ".$table_name."";
echo $sql;
$resource = mysql_query($sql) or die(mysql_error());
}
if($return_type == 'resource') {
return $resource;
}
if($return_type == 'resource_array') {
return mysql_fetch_assoc($resource);
}
if($return_type == 'resource_array_value') {
$resource_array = mysql_fetch_assoc($resource);
return $resource_array[$return_type_name];
}
}
$data = fetch_resource_db_nowhere('fix_data',array('course','branch','name'),'resource','');