我想使用单个查询更新MySQL表中的多个记录.基本上,这是一个任务表,它在不同的日期为不同的人分配.当通过在线表单更改和提交这些作业时,会提交大量POST数据(几乎所有待处理的作业).我编写了一个算法来对所有这些信息进行排序并得到我想要的信息,但我仍然坚持编写查询来更新MySQL表:
// Find the modified records and save their information
$update = 0;
for ( $n = 0; $n < $total_records; $n++ )
{
if ( $_POST['update'.$n] == true )
{
$updates_arr[$update] = array( intval($_POST['user_id'.$n]), intval($_POST['task'.$n]), $_POST['date'.$n] );
$update++;
}
}
if ( $mysql_db = OpenDatabase() )
{
$query = "UPDATE tasks_tbl";
if ( $updates_arr[0] )
{
$query .= " SET task = ".$updates_arr[0][1]." WHERE user_id = ".$updates_arr[0][0]." AND date = ".$updates_arr[0][2];
}
for ( $n = 1; $n < $updates; $n++ )
{
$query .= ", SET task = ".$updates_arr[$n][1]." WHERE user_id = ".$updates_arr[$n][0]." AND date = ".$updates_arr[$n][2];
}
$result = mysql_query( $query, $mysql_db );
if ( $result )
{
$page .= "<p>Success!</p>\n\n";
}
else
{
$page .= "<p>Error: ".mysql_error()."</p>\n\n";
}
}
Run Code Online (Sandbox Code Playgroud)
这是生成的查询:
UPDATE tasks_tbl
SET task = 1
WHERE user_id = 16
AND date = 2010-05-05,
SET task = 1
WHERE user_id = 17
AND date = 2222-02-22
Run Code Online (Sandbox Code Playgroud)
任何建议,将不胜感激.谢谢.
您可以生成如下查询:
UPDATE tasks_tbl SET task=1 WHERE
(user_id=16 AND date='2010-05-05') OR
(user_id=17 AND date='2010-02-22')
Run Code Online (Sandbox Code Playgroud)
有些黑客可以避免使用(... and ...) or (... and ...)构造(连接字段和参数:"concat(user_id, date) = '". $user_id. $date. "'"但是它们的工作速度稍慢.
PHP代码:
for ($i = 0; !empty($_POST['update'. $i]; $i++)
if (intval($_POST['task'.$i]) == 1)
$cond[] = '(user_id='. intval($_POST['user_id'. $i]).
' and date=\''. mysql_real_escape_string($_POST['date'.$i]). '\')';
$query = 'UPDATE tasks_tbl SET task=1 WHERE '. implode(' OR ', $cond). ')';
Run Code Online (Sandbox Code Playgroud)
编辑:我不太明白为什么你需要在一个查询中这样做.task可以有多少个值?1,2,3或更多?使用3个值,您可以使用嵌套IF(...)函数:
UPDATE tasks_tbl SET task=if('. <imploded tasks with value 1>. ', 1, if('.
<tasks with value 2>. ', 2, if('. <tasks with 3>. ', 3,
task))) /* leave as is otherwise */
Run Code Online (Sandbox Code Playgroud)
或者你可以在我给出的代码上放一个简单的循环:
for ($j = 1; $j <= 3; $j++)
for ($i = 0; !empty($_POST['update'. $i]; $i++)
if (intval($_POST['task'.$i]) == 1)
$cond[] = '(user_id='. intval($_POST['user_id'. $i]).
' and date=\''. mysql_real_escape_string($_POST['date'.$i]). '\')';
mysql_query('UPDATE tasks_tbl SET task=1 WHERE '. implode(' OR ', $cond). ')');
Run Code Online (Sandbox Code Playgroud)