Mysql:The CSV Storage Engine
注意:
1)表定义(换句话说)数据列必须不能为空Null!
2)修复表,极有可能丢失数据
The CSV
storage engine stores data in text files using comma-separated values format.
The CSV
storage engine is always compiled into the MySQL server.
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 plain text data file having a name that begins with the table name and has a .CSV
extension. When you store data into the table, the storage engine saves it into the data file in comma-separated values format.
CREATE TABLE test (i INT NOT NULL, c CHAR(10) NOT NULL) ENGINE = CSV; INSERT INTO test VALUES(1,'record one'),(2,'record two'); SELECT * FROM test;
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.
The CSV
storage engine supports the CHECK TABLE
and REPAIR TABLE
statements to verify and, if possible, repair a damaged CSV
table.
When running the CHECK TABLE
statement, the CSV
file will be checked for validity by looking for the correct field separators, escaped fields (matching or missing quotation marks), the correct number of fields compared to the table definition and the existence of a corresponding CSV
metafile. The first invalid row discovered will report an error. Checking a valid table produces output like that shown below:
mysql> CHECK TABLE csvtest;
+--------------+-------+----------+----------+
| Table | Op | Msg_type | Msg_text |
+--------------+-------+----------+----------+
| test.csvtest | check | status | OK |
+--------------+-------+----------+----------+
A check on a corrupted table returns a fault:
mysql> CHECK TABLE csvtest;
+--------------+-------+----------+----------+
| Table | Op | Msg_type | Msg_text |
+--------------+-------+----------+----------+
| test.csvtest | check | error | Corrupt |
+--------------+-------+----------+----------+
If the check fails, the table is marked as crashed (corrupt). Once a table has been marked as corrupt, it is automatically repaired when you next run CHECK TABLE
or execute a SELECT
statement. The corresponding corrupt status and new status will be displayed when running CHECK TABLE
:
mysql> CHECK TABLE csvtest;
+--------------+-------+----------+----------------------------+
| Table | Op | Msg_type | Msg_text |
+--------------+-------+----------+----------------------------+
| test.csvtest | check | warning | Table is marked as crashed |
| test.csvtest | check | status | OK |
+--------------+-------+----------+----------------------------+
To repair a table, use REPAIR TABLE
, which copies as many valid rows from the existing CSV
data as possible, and then replaces the existing CSV
file with the recovered rows. Any rows beyond the corrupted data are lost.
mysql> REPAIR TABLE csvtest;
+--------------+--------+----------+----------+
| Table | Op | Msg_type | Msg_text |
+--------------+--------+----------+----------+
| test.csvtest | repair | status | OK |
+--------------+--------+----------+----------+
During repair, only the rows from the CSV
file up to the first damaged row are copied to the new table. All other rows from the first damaged row to the end of the table are removed, even valid rows.
The CSV
storage engine does not support indexing.
The CSV
storage engine does not support partitioning.
All tables that you create using the CSV
storage engine must have the NOT NULL
attribute on all columns.
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
2019-03-17 PXE(preboot execution environment):【网络】预启动执行环节:引导 live光盘 ubuntu livecd 18.04+:成功
2010-03-17 Linux:Ubuntu使用iscsi
2010-03-17 Linux:vmware下ubuntu更换网卡后无法识别网卡
2009-03-17 Oracle学习笔记:创建physical standby之另类方法