6
function cpanel_populate_database($dbname) 
{ 
     // populate database
     $sql = file_get_contents(dirname(__FILE__) . '/PHP-Point-Of-Sale/database/database.sql');
     $mysqli->multi_query($sql);

     $mysqli->close();
 }

sql 文件是从 phpMyAdmin 直接导出的,大约 95% 的时间运行没有问题,所有表都已创建并插入数据。(我正在从头开始创建数据库)

其他 5% 仅创建第一个表或有时创建前 4 个表,但没有创建其他表(有 30 个表)。

我决定不使用 multi_query 因为它看起来有问题,并通过在分号后的每一行上仅使用 mysql_query 来查看错误是否发生。有没有人遇到过这样的问题?

4

4 回答 4

12

快速有效

system('mysql -h #username# -u #username# -p #database# < #dump_file#');
于 2011-09-23T06:35:41.693 回答
2

multi_query在使用可以创建或更改表的查询时,我看到了类似的问题。特别是,我倾向于得到似乎与外键有关的 InnoDB 1005 错误;就像 MySQL 在继续下一个语句之前没有完全完成一个语句,因此外键缺少适当的引用。

在一个系统中,我将有问题的语句拆分到它们自己的文件中。在另一个方面,我确实分别运行了每个命令,用分号分开:

function load_sql_file($basename, $db) {
    // Todo: Trim comments from the end of a line
    log_upgrade("Attempting to run the `$basename` upgrade.");

    $filename = dirname(__FILE__)."/sql/$basename.sql";
    if (!file_exists($filename)) {
        log_upgrade("Upgrade file `$filename` does not exist.");
        return false;
    }

    $file_content = file($filename);
    $query = '';
    foreach ($file_content as $sql_line) {
        $tsl = trim($sql_line);
        if ($sql_line and (substr($tsl, 0, 2) != '--') and (substr($tsl, 0, 1) != '#')) {
            $query .= $sql_line;
            if (substr($tsl, -1) == ';') {
                set_time_limit(300);
                $sql = trim($query, "\0.. ;");
                $result = $db->execute($sql);
                if (!$result) {
                    log_upgrade("Failure in `$basename` upgrade:\n$sql");
                    if ($error = $db->lastError()) {
                        log_upgrade("$error");
                    }

                    return false;
                }

                $query = '';
            }
        }
    }

    $remainder = trim($query);
    if ($remainder) {
        log_upgrade("Trailing text in `$basename` upgrade:\n$remainder");
        if (DEBUG) trigger_error('Trailing text in upgrade script: '.$remainder, E_USER_WARNING);
        return false;
    }

    log_upgrade("`$basename` upgrade successful.");
    return true;
}
于 2011-09-23T18:34:52.527 回答
0

我从来没有诉诸多查询。当我需要类似的东西时,我搬到了mysqli。此外,如果您不需要查询的任何结果,则将脚本传递给 mysql_query 也可以。如果导出的顺序不正确,与外键的要求表和其他表发生冲突,您也会收到这些错误。

于 2011-09-19T13:34:04.057 回答
0

我认为将 SQL 文件分解为单个查询的方法是一个好主意。即使它只是为了比较目的(看看它是否解决了问题)。

另外,我不确定你的文件有多大——但我遇到过一些文件非常大的情况,并且将它分成几批就可以了。

于 2011-09-19T13:37:47.033 回答