#php #mysql
#php #mysql
Вопрос:
Я пытаюсь экспортировать данные из таблицы mysql.
Запрос, который я написал, выполняется правильно в sql workbench, и я вижу результат этого, но если я использую тот же запрос в своем коде, он выдает ошибку.
Ошибка
У вас ошибка в вашем синтаксисе SQL; проверьте руководство, соответствующее вашей версии сервера MySQL, на предмет правильного синтаксиса для использования рядом с «ПОДГОТОВИТЬ данные ИЗ @ sql; ВЫПОЛНИТЬ данные» в строке 5
sql-запрос
$sql = "SET @sql = CONCAT('SELECT ', (SELECT GROUP_CONCAT(COLUMN_NAME) FROM
information_schema.columns WHERE table_schema = 'wpdb_wp1' AND table_name =
'wp3_wpsp_ticket' AND column_name NOT IN ('guest_name', 'guest_email')),
' from wpdb_wp1.wp3_wpsp_ticket limit 1');
PREPARE data FROM @sql;
EXECUTE data;";
код
$Connect = @mysql_connect($DB_Server, $DB_Username, $DB_Password) or die("Couldn't connect to MySQL:<br>" . mysql_error() . "<br>" . mysql_errno());
//select database
$Db = @mysql_select_db($DB_DBName, $Connect) or die("Couldn't select database:<br>" . mysql_error(). "<br>" . mysql_errno());
//execute query
$result = @mysql_query($sql,$Connect) or die("Couldn't execute query:<br>" . mysql_error(). "<br>" . mysql_errno());
$file_ending = "xls";
//header info for browser
header("Content-Type: application/xls");
header("Content-Disposition: attachment; filename=$filename.xls");
header("Pragma: no-cache");
header("Expires: 0");
/*******Start of Formatting for Excel*******/
//define separator (defines columns in excel amp; tabs in word)
$sep = "t"; //tabbed character
//start of printing column names as names of MySQL fields
for ($i = 0; $i < mysql_num_fields($result); $i ) {
echo mysql_field_name($result,$i) . "t";
}
print("n");
//end of printing column names
//start while loop to get data
while($row = mysql_fetch_row($result))
{
$schema_insert = "";
for($j=0; $j<mysql_num_fields($result);$j )
{
if(!isset($row[$j]))
$schema_insert .= "NULL".$sep;
elseif ($row[$j] != "")
$schema_insert .= "$row[$j]".$sep;
else
$schema_insert .= "".$sep;
}
$schema_insert = str_replace($sep."$", "", $schema_insert);
$schema_insert = preg_replace("/rn|nr|n|r/", " ", $schema_insert);
$schema_insert .= "t";
print(trim($schema_insert));
print "n";
}
Может ли кто-нибудь помочь мне в этом?
Ответ №1:
mysql_query() не может выполнить несколько инструкций sql за один раз. Точка.
mysql_query() отправляет уникальный запрос (несколько запросов не поддерживаются) в текущую активную базу данных на сервере, которая связана с указанным идентификатором link_identifier.
Вы можете использовать несколько mysql_query(
) вызовов, по одному для каждого оператора. Но прежде чем делать это, посмотрите следующий пункт.
Пожалуйста, не используйте функции mysql_*(), они устарели в течение многих лет и были удалены из php 7.0. Вместо этого используйте mylsqi или PDO.
Предупреждение Это расширение устарело в PHP 5.5.0, и оно было удалено в PHP 7.0.0. Вместо этого следует использовать расширение MySQLi или PDO_MySQL. Смотрите также MySQL: руководство по выбору API и связанные часто задаваемые вопросы для получения дополнительной информации.
Комментарии:
1. спасибо за ваш ответ … я приму ваше предложение …… я попытаюсь использовать PDO или mysqli ….. также я попытался выполнить sql один за другим … ошибка ушла, но вывод не пришел
2. Тогда это другой вопрос. Хотя я не уверен, что стоит беспокоиться о динамическом определении списка полей. В надлежащем приложении структура базы данных не должна меняться так часто. Даже если вы идете по динамическому маршруту, может быть проще вернуть список полей в php и использовать обычный запрос, а не использовать подготовленную инструкцию.
3. теперь без ошибок я могу экспортировать файл, но данные там не отображаются
4. Как я уже сказал, это другой вопрос, пожалуйста, задайте его в отдельном сообщении вместе с отладочной информацией. На этот конкретный вопрос был дан ответ.