0

PHP を使用して CSV にエクスポートし、mySQL にクエリを実行して CSV に入力する方法を知っています。ただし、ユーザーが必要な列を選択し、それに応じて SQL クエリを変更することは可能ですか?

データベースへの接続を確立し、次のクエリを追加しました。

$query = sprintf("SELECT x, y, z from a");
$result = mysql_query( $query, $conn ) or die( mysql_error( $conn ) );
header( 'Content-Type: text/csv' );
header( 'Content-Disposition: attachment;filename=export.csv' );
$row = mysql_fetch_assoc( $result );
if ( $row )
{
echocsv( array_keys( $row ) );
}
while ( $row )
{
echocsv( $row );
$row = mysql_fetch_assoc( $result );
}
function echocsv( $fields )
{
$separator = '';
foreach ( $fields as $field )
{
  if ( preg_match( '/\\r|\\n|,|"/', $field ) )
  {
    $field = '"' . str_replace( '"', '""', $field ) . '"';
  }
  echo $separator . $field;
  $separator = ',';
}
echo "\r\n";
}
4

1 に答える 1

2

はい、そうです。ユーザーがエクスポートするフィールドを選択するフォームを作成する必要があります。取得できるすべての可能なデータベースフィールドをリストするチェックボックスリストで考え、ユーザーの選択に従ってクエリを作成します。例:

<form action="" method="post">
    <label><input name="fields[]" type="checkbox" value="name"> Username</label>
    <label><input name="fields[]" type="checkbox" value="birthdate"> Birthdate</label>
</form>

次に、サーバー側でデータベース クエリを作成します。

$sql = "SELECT `". implode("`, `", $_POST["fields"]) ."` FROM db_table";

この助けを願っています。

于 2012-02-08T03:26:08.443 に答える