- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个表,其中包含带有订单字段的项目,我用这些字段将它们画在树上。
CREATE TABLE items (
menuId INTEGER,
itemId INTEGER,
name VARCHAR,
order1 INTEGER,
order2 INTEGER,
order3 INTEGER,
order4 INTEGER,
);
主键是 'menuId' 和 'itemId'。
“menuId”与表“menus”的外键。
对于每个菜单,我都有一个唯一的检查,例如,对于 menu1,我不能有两个具有相同组合顺序的项目,但 menu2 可以。
我想创建一个触发器,当我插入或更新一个项目时触发,所以如果添加一个订单为 2 的新项目,订单为 2 的更新为 3,订单 3 为 4,依此类推。现在我不关心订单之间是否有空格,这是我稍后会尝试解决的问题。
触发器是这样的:
CREATE TRIGGER trg_items_menu_bibu
BEFORE INSERT OR UPDATE
ON items
FOR EACH ROW
EXECUTE PROCEDURE update_menu_order();
CREATE OR REPLACE FUNCTION update_menu_order()
RETURNS trigger AS
$BODY$
BEGIN
IF EXISTS (SELECT name
FROM items
WHERE order1 = NEW.order1
AND order2 = NEW.order2
AND order3 = NEW.order3
AND order4 = NEW.order4
AND menuId = NEW.menuId
AND itemId <> NEW.itemId) THEN
-- If exists an item for that menu with the same orders
IF (NEW.order4 <> 0) THEN
-- If it's an item in the sublevel4
UPDATE items SET order4 = order4 + 1
WHERE order1 = NEW.order1
AND order2 = NEW.order2
AND order3 = NEW.order3
AND order4 = NEW.order4
AND menuId = NEW.menuId
AND itemId <> NEW.itemId;
ELSEIF (NEW.order3 <> 0) THEN
-- If it's an item in the sublevel3
UPDATE items SET order3 = order3 + 1
WHERE order1 = NEW.order1
AND order2 = NEW.order2
AND order3 = NEW.order3
AND order4 = 0
AND menuId = NEW.menuId
AND itemId <> NEW.itemId;
ELSEIF (NEW.order2 <> 0) THEN
-- If it's an item in the sublevel2
UPDATE items SET order2 = order2 + 1
WHERE order1 = NEW.order1
AND order2 = NEW.order2
AND order3 = 0
AND order4 = 0
AND menuId = NEW.menuId
AND itemId <> NEW.itemId;
ELSE
-- If it's an item in the sublevel1
UPDATE items SET order1 = order1 + 1
WHERE order1 = NEW.order1
AND order2 = 0
AND order3 = 0
AND order4 = 0
AND menuId = NEW.menuId
AND itemId <> NEW.itemId;
END IF;
END IF;
RETURN NEW;
END;
$BODY$
LANGUAGE plpgsql;
如果我有这些元素:
menuId itemId name order1 order2 order3 order4
1 1 menu1 1 0 0 0
1 2 menu2 1 1 0 0
1 3 menu3 1 2 0 0
然后我尝试插入以下内容:
menuId itemId name order1 order2 order3 order4
1 4 menu4 1 1 0 0
触发器正确更新为:
menuId itemId name order1 order2 order3 order4
1 1 menu1 1 0 0 0
1 4 menu4 1 1 0 0
1 2 menu2 1 2 0 0
1 3 menu3 1 3 0 0
但如果我尝试更新:
1 3 menu3 1 1 0 0
我收到一条错误消息,指出要修改的一行已被修改。
我理解问题是触发器让menu2更新order2为3,它强制menu3更新order2为4,但是menu3已经被原来的更新修改了。
我不知道如何解决这个问题,或者是否有可能。
最佳答案
对订单使用 double
而不是整数
。
这样,您始终可以在两个现有商品之间插入一个新商品,只需使用订单的平均值即可。
最大的优势是无需修改任何现有条目,因此您根本不需要触发器。
这将与 ORDER BY
一起正常工作;如果出于任何原因您需要显示整数顺序,请使用 dense_rank
窗口函数在查询中生成它。
关于SQL 触发器 : row to be modified was already modified,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58524614/
我有一个表,其中包含带有订单字段的项目,我用这些字段将它们画在树上。 CREATE TABLE items ( menuId INTEGER, itemId INTEGER,
我正在关注这个 YouTube他们使用的教程Modifier.preferredSize()在一个盒子上和 Modifier.preferredHeight()在 Spacer Composable
当删除包含 UserSession.insert 的 if 语句时,一切正常。但是当它被包含时,我们会收到有关无效修饰符的错误。 出了什么问题?谢谢! 服务器/helpers/b.s Meteor.s
我已经为我的 Android 项目构建了一个注释处理器,它使用 JavaPoet 构建了一个源文件。但是,每次我需要对任何 JavaPoet 对象调用 addModifiers 时,Android S
我应该在哪里设置像 CreatedDate、CreatedBy、ModifiedDate、ModifiedBy 这样的字段?我应该将当前用户上下文传递到存储库并将其设置在那里,还是更好的方法是在应用程
我可以以某种方式重构以下代码片段以摆脱 双修饰符声明 ? .block { &__element { rule: value; } &--modifier { rule:
我正在编写一个函数,它接受一个谓词 p 和一个列表。它返回 ([value],[state]),其中第一个列表包含通过 p 的元素,第二个列表包含未通过的元素。但是,当我运行 runState (my
在我的项目中,我使用了 Typescript@4.0.3它运行良好,但现在我将其版本更新为最新 Typescript@4.1.3它给了我很多错误。我无法在文档中找到任何内容,也没有任何想法如何解决此问
我正在开发一个通过表单发送数据的 Rails 应用程序。我想在表单发送之后,但在它被处理之前修改表单的一些“参数”。 我现在拥有的 {"commit"=>"Create", "authentici
我的问题是关于接口(interface)。我创建了一个接口(interface)并定义了四个方法:第一个方法是 private 方法;第二个是 default 方法;第三个是static方法;第四个是
好的,所以我当前正在尝试选择目录中的最新文件(本例中为/FSTP/LOGS),但我想忽略包含字符串“DEBUG - null”但不是字符串的任何文件“DEBUG - MA”或“INFO - MA”。这
正是标题所说的。 Modifier.heightIn(...) 和有什么区别和 Modifier.prefferedHeigh() .在我的试验中,它们似乎以相同的方式工作。有谁知道何时使用什么以及在
我在项目中使用 Android Volley Networking 库。 当我自己将带有 etag 的“if-None-Match”添加到 header 时,我没有得到 304,因为 Volley 还
我一直在阅读一些关于在从服务器发送响应时为 Last-Modified 设置 header 的文章。我了解它的用途,以及如何设置它等。 我也理解传入的 If-Modified-Since header
我一直在浏览 Ivy 文档,但我对默认 ivysettings.xml 有疑问在 ivy.jar 中找到。 我要做的就是将公共(public)存储库更改为我们拥有的本地 Maven 存储库。就是这样。
我是 Ruby 新手。这是一个使用任何语言的编程面试问题。我正在尝试用 Ruby 来做。 编写一个程序来输入给定的句子。用单词的第一个字母/#ofcharactersbetween1st&laSTLe
我收到以下代码A的警告信息,为什么? 可选的 Modifier 参数应具有默认值 Modifier 代码A @Composable fun DisplayIcon( modifier: Mod
假设我想创建一个 Column与最宽的 child 一样宽Text在里面。为此,该列可以使用 .wrapContentWidth() 修饰符或 .width(IntrinsicSize.Max) ,但
我正在尝试用 Javascript 编写实现图形(数据结构)。为此,我有一个名为 Graph 的函数将该矩阵存储在名为 this.adjMatrix 的属性中的二维数组中。它还有很多方法。 我还想创建
即使在 Google PageSpeed(97) 和 Yahoo! YSlow(92) PHP 生成的缩略图似乎并不是被动地从旧缓存中获取的:它们似乎每次都生成......又一次......新鲜出炉,
我是一名优秀的程序员,十分优秀!