0

我有一个名为的列list,按我的顺序使用(在 MYSQL 查询中),列表中是数字:(例如 1 到 20)

然后,该列表由listASC 使用 MYSQL 顺序输出 - 但是,当我使用 Jquery 拖放 UI 列表在后端更新我的列表时,它应该更新列表前端。

我的问题是我的列表顺序有时会与其他行冲突,因为列表中可能有两到三行值为 1,因此当我的订单更新时,我想知道如何仅当行更新其他行时 +1是 >= 给定的订单号

我不想使列成为主要列,因为我的目标不是使list列唯一,原因是因为有多个类别 - 在每个类别中它们都从 1 开始 - 因此,如果我让它独一无二会导致错误,因为在不同的类别中有多个 1。

我问了一位朋友,他说我可能可以使用触发器函数尝试 PL/SQL,但这对我来说是新的领域——我不完全理解那种语言,想知道是否有人可以帮助我做我正在尝试使用 MYSQL 或甚至是 PL/SQL。

这是我到目前为止所拥有的:

<?php
$project = mysql_real_escape_string(stripslashes($_POST['pid']));
$category = mysql_real_escape_string(stripslashes($_POST['cat']));
$order = mysql_real_escape_string(stripslashes($_POST['order']));
// need to do update the moved result (list row) and update all conflicting rows by 1
mysql_query("UPDATE `projects` SET `cat`='$category',`list`='$order' WHERE `id`='$project'")or die(mysql_query());
?>

结论:

我正在尝试更新一个非唯一列以具有该单个类别的唯一值。我不确定如何通过 +1 更新该类别中的所有行

4

2 回答 2

2

@andrewsi 是对的,特别是我建议order by list ASC, last_update DESC在您更新的同一查询中添加list时间戳last_update,因此您无需使用触发器或任何其他更新。

于 2012-08-09T20:17:19.160 回答
2

总的来说,andrewsi 和 Luis 的建议是正确的。而不是(像 andrewsi 说的)“做混乱的更新”,你应该真正考虑按第二列排序。

但是,我也许可以看到您对方法的看法。我知道它可能适用的一种类似情况是在 CMS 中,您可以通过在项目旁边的文本字段中手动更改订单号来让后端用户订购项目,例如

item 1 - [ 1 ]
item 2 - [ 3 ]
item 3 - [ 2 ]

... 中的数字[]将成为新订单。

所以,一个非常混乱的解决方案是(很多步骤,但如果你不必担心性能,它可能对你没问题,我不知道):

INSERT INTO projects (cat, list, timestamp_inserted) VALUES (:cat, :list, NOW())

然后作为第二步

SELECT id, list FROM projects WHERE cat=:cat ORDER BY list ASC, timestamp_inserted DESC

然后循环遍历从 select 和 foreach 行更新中获得的数组(:i 是递增索引)

UPDATE projects SET list=:i WHERE id=:id

PS:您必须添加一个timestamp_inserted带有时间戳值的列。
PPS:明确地说,我不推荐这样做,也从未说过这是最佳做法(对于那些考虑因此而投票反对的人)

于 2012-08-09T21:12:26.367 回答