PHP Classes

How to Use a PHP CSV Export Library to Generate CSV Files From MySQL Query Results Using the Package PHP MySQL Query CSV Export and Download: Export or download MySQL query as a CSV file

Recommend this page to a friend!
     
  Info   View files Files   Install with Composer Install with Composer   Download Download   Reputation   Support forum   Blog    
Last Updated Ratings Unique User Downloads Download Rankings
2025-10-07 (4 hours ago) RSS 2.0 feedNot enough user ratingsTotal: 99 All time: 9,822 This week: 59Up
Version License PHP version Categories
exportcsv 1.0.2MIT/X Consortium ...5PHP 5, Databases, Files and Folders, U..., C...
Description 

Author

This class can export MySQL query results as a CSV file.

It can execute a given SQL query using the MySQL command line shell program to save the query results as a CSV file to avoid exceeding the PHP memory limit, especially when the query results return over 30,000 records.

The package can serve the generated CSV file to let users download it.

Picture of Ramesh Narayan Jangid (Sharma)
  Performance   Level  
Name: Ramesh Narayan Jangid ... <contact>
Classes: 11 packages by
Country: India India
Innovation award
Innovation award
Nominee: 5x

Winner: 4x

Instructions

Large CSV export

If you are facing difficulty in performing large MySQL query export to CSV operation in PHP; then this is the class for you.

Steps to perform this.

Configure your connection

define('HOSTNAME', '127.0.0.1'); 
define('USERNAME', 'username'); 
define('PASSWORD', 'password'); 
define('DATABASE', 'database'); 

Prepare your parameterised query

$sql = "
    SELECT
        column1 as COLUMN1,
        column2 as COLUMN2,
        column3 as COLUMN3,
        column4 as COLUMN4
    FROM
        TABLE_NAME
    WHERE
        column5 = :column5
        column6 LIKE CONCAT('%' , :column6, '%');
        column7 IN (:column7);
";

Prepare your parameterised params array

$params = [
    ':column5' => 'column5_value',
    ':column6' => 'column6_search_value',
    ':column7' => [
        'column7_value1',
        'column7_value2',
        'column7_value3'
    ]
];

Execute and export.

$csvFilename = 'export.csv'; 

try { 
  $mySqlCsv = new downloadCSV(); 
  $mySqlCsv->connect(HOSTNAME, USERNAME, PASSWORD, DATABASE);
  $mySqlCsv->useTmpFile = false; // defaults true for large data export.
  $mySqlCsv->initDownload($csvFilename, $sql, $params);
} catch (\Exception $e) { 
  echo $e->getMessage(); 
} 

Details

Export CSV

Export / Download MySQL query results as a CSV file

When it comes to Download CSV, most of the time developer faces issue of memory limit in PHP; especially when supporting downloads of more than 30,000 records at a time.

Below class solves this issue by executing shell command for MySql Client installed on the server from PHP script. Using this class one can download all the records in one go. There is no limit to number of rows returned by SQL query.<br>

Examples

To download the export CSV

<?php

require_once __DIR__ . '/AutoloadExportCSV.php';

use ExportCSV\ExportCSV;

define(constant_name: 'HOSTNAME', value: '127.0.0.1');
define(constant_name: 'USERNAME', value: 'username');
define(constant_name: 'PASSWORD', value: 'password');
define(constant_name: 'DATABASE', value: 'database');

$sql = "
    SELECT
        column1 as COLUMN1,
        column2 as COLUMN2,
        column3 as COLUMN3,
        column4 as COLUMN4
    FROM
        TABLE_NAME
    WHERE
        column5 = :column5
        column6 LIKE CONCAT('%' , :column6, '%');
        column7 IN (:column7);
";

$params = [
    ':column5' => 'column5_value',
    ':column6' => 'column6_search_value',
    ':column7' => [
        'column7_value1',
        'column7_value2',
        'column7_value3'
    ]
];

$csvFilename = 'export.csv';

try {
    $exportCSV = new ExportCSV(dbType: 'MySQL');
    $exportCSV->connect(
        hostname: HOSTNAME,
        username: USERNAME,
        password: PASSWORD,
        database: DATABASE
    );
    $exportCSV->useTmpFile = false; // defaults true for large data export.
    $exportCSV->initDownload(
        csvFilename: $csvFilename,
        sql: $sql,
        params: $params
    );
} catch (\Exception $e) {
    echo $e->getMessage();
}

To export the CSV results in a file.

<?php

require_once __DIR__ . '/AutoloadExportCSV.php';

use ExportCSV\ExportCSV;

define(constant_name: 'HOSTNAME', value: '127.0.0.1');
define(constant_name: 'USERNAME', value: 'username');
define(constant_name: 'PASSWORD', value: 'password');
define(constant_name: 'DATABASE', value: 'database');

$sql = "
    SELECT
        column1 as COLUMN1,
        column2 as COLUMN2,
        column3 as COLUMN3,
        column4 as COLUMN4
    FROM
        TABLE_NAME
    WHERE
        column5 = :column5
        column6 LIKE CONCAT('%' , :column6, '%');
        column7 IN (:column7);
";

$params = [
    ':column5' => 'column5_value',
    ':column6' => 'column6_search_value',
    ':column7' => [
        'column7_value1',
        'column7_value2',
        'column7_value3'
    ]
];

$csvAbsoluteFilePath = '/<folder path>/<filename>.csv';

try {
    $exportCSV = new ExportCSV(dbType: 'MySQL');
    $exportCSV->connect(
        hostname: HOSTNAME,
        username: USERNAME,
        password: PASSWORD,
        database: DATABASE
    );
    $exportCSV->saveCsvExport(
        sql: $sql,
        params: $params,
        csvAbsoluteFilePath:  $csvAbsoluteFilePath
    );
} catch (\Exception $e) {
    echo $e->getMessage();
}

To download as well as export the CSV results in a file.

<?php

require_once __DIR__ . '/AutoloadExportCSV.php';

use ExportCSV\ExportCSV;

define(constant_name: 'HOSTNAME', value: '127.0.0.1');
define(constant_name: 'USERNAME', value: 'username');
define(constant_name: 'PASSWORD', value: 'password');
define(constant_name: 'DATABASE', value: 'database');

$sql = "
    SELECT
        column1 as COLUMN1,
        column2 as COLUMN2,
        column3 as COLUMN3,
        column4 as COLUMN4
    FROM
        TABLE_NAME
    WHERE
        column5 = :column5
        column6 LIKE CONCAT('%' , :column6, '%');
        column7 IN (:column7);
";

$params = [
    ':column5' => 'column5_value',
    ':column6' => 'column6_search_value',
    ':column7' => [
        'column7_value1',
        'column7_value2',
        'column7_value3'
    ]
];

$csvFilename = 'data.csv';
$csvAbsoluteFilePath = '/<folder path>/<filename>.csv';

try {
    $exportCSV = new ExportCSV(dbType: 'MySQL');
    $exportCSV->connect(
        hostname: HOSTNAME,
        username: USERNAME,
        password: PASSWORD,
        database: DATABASE
    );
    $exportCSV->initDownload(
        csvFilename: $csvFilename,
        sql: $sql,
        params: $params,
        csvAbsoluteFilePath: $csvAbsoluteFilePath
    );
} catch (\Exception $e) {
    echo $e->getMessage();
}

Compression

To enable compression for downloading dynamically generated CSV files in NGINX if the browser supports compression, one can use the gzip\_types directive in the NGINX configuration file.

The gzip\_types directive is used to specify which MIME types should be compressed.

Here's an example of how you can enable compression for downloading dynamically generated CSV files in NGINX:

http {
    # ...
    gzip on;
    gzip_types text/plain text/csv;
    # ...
}

  Files folder image Files (10)  
File Role Description
Files folder imageExportCSV (4 files)
Plain text file Autoload.php Class Class source
Accessible without login Plain text file AutoloadExportCSV.php Aux. Configuration script
Accessible without login Plain text file Config.php Aux. Configuration script
Accessible without login Plain text file Example.php Example Example script
Accessible without login Plain text file LICENSE Lic. License text
Accessible without login Plain text file README.md Doc. Documentation

  Files folder image Files (10)  /  ExportCSV  
File Role Description
  Plain text file DB.php Class Class source
  Plain text file DBInterface.php Class Class source
  Plain text file ExportCSV.php Class Class source
  Plain text file MySQL.php Class Class source

The PHP Classes site has supported package installation using the Composer tool since 2013, as you may verify by reading this instructions page.
Install with Composer Install with Composer
 Version Control Unique User Downloads Download Rankings  
 100%
Total:99
This week:0
All time:9,822
This week:59Up