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来发生错误。有没有人遇到像这样的问题?
答案 0 :(得分:12)
快速有效
system('mysql -h #username# -u #username# -p #database# < #dump_file#');
答案 1 :(得分: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;
}
答案 2 :(得分:0)
我从未使用过多次查询。当我需要这样的东西时,我转移到mysqli。此外,如果您不需要查询的任何结果,将脚本传递给mysql_query也将起作用。如果导出的错误顺序与外键和其他的需要表冲突,你也会得到这些错误。
答案 3 :(得分:0)
我认为将SQL文件分解为单一查询的方法是个好主意。即使它仅用于比较目的(看它是否解决了问题)。
另外,我不确定你的文件有多大 - 但我有几个案例,文件非常大,将它分成批次就完成了工作。