The CSV storage engine stores data in text files
    using comma-separated values format.
  
    To enable the CSV storage engine if you build
    MySQL from source, invoke configure with the
    --with-csv-storage-engine option.
  
    To examine the source for the CSV engine, look in
    the storage/csv directory of a MySQL source
    distribution.
  
    When you create a CSV table, the server creates a
    table format file in the database directory. The file begins with
    the table name and has an .frm extension. The
    storage engine also creates a data file. Its name begins with the
    table name and has a .CSV extension. The data
    file is a plain text file. When you store data into the table, the
    storage engine saves it into the data file in comma-separated values
    format.
  
mysql>CREATE TABLE test (i INT NOT NULL, c CHAR(10) NOT NULL)->ENGINE = CSV;Query OK, 0 rows affected (0.12 sec) mysql>INSERT INTO test VALUES(1,'record one'),(2,'record two');Query OK, 2 rows affected (0.00 sec) Records: 2 Duplicates: 0 Warnings: 0 mysql>SELECT * FROM test;+------+------------+ | i | c | +------+------------+ | 1 | record one | | 2 | record two | +------+------------+ 2 rows in set (0.00 sec)
    Creating a CSV table also creates a corresponding Metafile that
    stores the state of the table and the number of rows that exist in
    the table. The name of this file is the same as the name of the
    table with the extension CSM.
  
    If you examine the test.CSV file in the
    database directory created by executing the preceding statements,
    its contents should look like this:
  
"1","record one" "2","record two"
This format can be read, and even written, by spreadsheet applications such as Microsoft Excel or StarOffice Calc.


User Comments
Using the windows version of mysql 5.1.11 beta:
CSV rows need to be terminated with a unix newline.
If you load a csv data into a csv table by replacing a blank csv table file, with a file already loaded with data, as described in csv overview, replacing new table with one already populated with data, and the data originates from a windows box, you need to first replace the \r\n with \n (windows linefeed/carriage return with a unix newline) or the table will not be loaded properly.
You will get a message about a crashed table when you attempt to access it.
Open file in a program like PFE 32 that can "Save As" replacing the crlf with unix newlines and mysql will then be able to access table normally.
Add your own comment.