Mysql 按日期拆分数据库

Mysql 按日期拆分数据库,mysql,sql,etl,Mysql,Sql,Etl,我在生产中有大型MySQL数据库(14GB)。有时我不得不下载它并在本地进行处理。这当然是个问题。该数据库有10个带有“日期”字段的表和5个没有“日期”字段的表 上个月有什么简单的方法可以下载吗?10个表格,条件为“数据>'2020-07-24'”,以及完整的5个其他表格。我想将它转储到一个.sql文件中,然后在本地导入它。 不幸的是,数据库在10个表之间有一些关系…是的,请查看mysqldump的--where选项。是的,请查看mysqldump的--where选项。尝试此代码,它必须是为任何

我在生产中有大型MySQL数据库(14GB)。有时我不得不下载它并在本地进行处理。这当然是个问题。该数据库有10个带有“日期”字段的表和5个没有“日期”字段的表

上个月有什么简单的方法可以下载吗?10个表格,条件为“数据>'2020-07-24'”,以及完整的5个其他表格。我想将它转储到一个.sql文件中,然后在本地导入它。
不幸的是,数据库在10个表之间有一些关系…

是的,请查看mysqldump的
--where
选项。

是的,请查看mysqldump的
--where
选项。

尝试此代码,它必须是为任何表创建列
CREATED\u DATE

我希望它能奏效:)

如果你需要谷歌硬盘的自动备份


试试这段代码,它必须是用来创建任何表的列
CREATED\u DATE

我希望它能奏效:)

如果你需要谷歌硬盘的自动备份


rewrite records to new tables?mysqldump有一个where条件,但是如果没有它,你就不能有表,所以做两次转储,一次有日期,一次没有日期。如果你告诉我们你将使用什么操作系统来完成下载/上传工作,这会很有帮助。请回答您的问题。将记录重写为新表?mysqldump有一个where条件,但如果没有它,您就不能有表,所以请执行两次转储,一次有日期,一次没有日期。如果您告诉我们您将使用什么操作系统来完成下载/上载工作,这将有所帮助。请回答你的问题。
<?php

// ini_set('memory_limit', '1024M'); 

// User home directory (absolute)
$homedir = "backup/"; // If this doesn't work, you can provide the full path yourself
// Site directory (relative)
$sitedir = ""; 
// Base filename for backup file
$fprefix = "sitebackup-";
// Base filename for database file
$dprefix = "dbbackup-";
// MySQL username
$dbuser = "root";
// MySQL password
$dbpass = "";
// MySQL database
$dbname = "";
// MySQL Host
$host = "localhost";

// Get connection object and set the charset
$conn = mysqli_connect($host, $dbuser, $dbpass, $dbname);
$conn->set_charset("utf8");
// Get All Table Names From the Database
$tables = array();
$sql = "SHOW TABLES";
$result = mysqli_query($conn, $sql);

while ($row = mysqli_fetch_row($result)) {
    $tables[] = $row[0];
}
$sqlScript = "";
foreach ($tables as $table) {
    
    // Prepare SQLscript for creating table structure
    $query = "SHOW CREATE TABLE $table";
    $result = mysqli_query($conn, $query);
    $row = mysqli_fetch_row($result);
    
    $sqlScript .= "\n\n" . $row[1] . ";\n\n";
    
    $form_date='2020-08-01';  // Split From Date 
    $to_date='2020-08-31'; // Split to Date

    $query = "SELECT * FROM $table "; // 
    // if you whant to use  Split the database by date
    // $query .=" WHERE CREATED_DATE >= DATE(CONCAT_WS('-', '2020', '08', '01')) AND  CREATED_DATE < DATE(CONCAT_WS('-', '2020', '08', '31'))"
    //   $query .="  WHERE CREATED_DATE >= '$form_date' AND  CREATED_DATE < '$to_date' ";

    $result = mysqli_query($conn, $query);
    
    $columnCount = mysqli_num_fields($result);
    
    // Prepare SQLscript for dumping data for each table
    for ($i = 0; $i < $columnCount; $i ++) {
        while ($row = mysqli_fetch_row($result)) {
            $sqlScript .= "INSERT INTO $table VALUES(";
            for ($j = 0; $j < $columnCount; $j ++) {
                $row[$j] = $row[$j];
                
                if (isset($row[$j])) {
                    $sqlScript .= '"' . $row[$j] . '"';
                } else {
                    $sqlScript .= '""';
                }
                if ($j < ($columnCount - 1)) {
                    $sqlScript .= ',';
                }
            }
            $sqlScript .= ");\n";
        }
    }
    
    $sqlScript .= "\n"; 
}

if(!empty($sqlScript))
{
    // Save the SQL script to a backup file
    $backup_file_name = $homedir.$dprefix.$dbname . '_' .   $uid . '.sql';
    $fileHandler = fopen($backup_file_name, 'w+');
    $number_of_lines = fwrite($fileHandler, $sqlScript);
    fclose($fileHandler); 
}