首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在SQLite触发器中实现If语句?

如何在SQLite触发器中实现If语句?
EN

Stack Overflow用户
提问于 2015-05-25 06:47:49
回答 2查看 1.5K关注 0票数 0

我们在SQLite数据库中定义了一个自引用关系.

代码语言:javascript
运行
复制
Create Table Categories{
    Id INTEGER PRIMARY KEY,
    Name TEXT NOT NULL CHECK(length(Text) > 0),
    ParentId INTEGER References Categories(Id),
    IsSelected BOOL
};

我们正在尝试在IsSelected字段上设置一个触发器,以自动传播到层次结构上的值。

当将值设置为True时,这很容易。我们只是将触发器设置为将其父级设置为True,这反过来也会对其父层执行相同的操作,即沿着层次结构向上走,直到到达根。

但是,当我们将其设置为False时,该逻辑不适用,因为可能会有另一个更改记录的兄弟关系仍然是真的,因此它的父级仍然是真的。

那么,如何在触发器中执行以下操作呢?注意,这显然是SQL、C#和LINQ的一个荒谬的混合体,但它说明了我想要做的事情。

代码语言:javascript
运行
复制
CREATE TRIGGER T_Categories_IsSelectedChanged
UPDATE OF IsSelected ON Categories
BEGIN
    if(new.IsSelected)
        Update Categories Set IsSelected = True Where Id = old.ParentId;
    else
    {
        void isSiblingSelected = Categories
            .Where(c => c.ParentId = old.ParentId)
            .Any(c => c.IsSelected);

        UPDATE Categories 
        SET IsSelected = isSiblingSelected
        WHERE Id = old.ParentId;
    }
END

现在,从技术上讲,在这两种情况下,“否则”条款都是有效的。如果是短路的话,也许我可以这样做.

代码语言:javascript
运行
复制
Update Categories
SET IsSelected = (
    SELECT EXISTS(SELECT 1 FROM Categories
    WHERE IsSelected = True 
    AND ParentId = old.ParentId
    LIMIT 1))
Where ID = old.ParentId;

...but,这只是猜测。我在正确的轨道上吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-05-25 18:17:56

CASE不是语句;只能在表达式中使用它。

但是,触发器有一个时间条款,它接受任意的SQL表达式:

代码语言:javascript
运行
复制
CREATE TRIGGER T_Categories_IsSelectedChanged_true
AFTER UPDATE OF IsSelected ON Categories
FOR EACH ROW
WHEN new.IsSelected
BEGIN
    UPDATE Categories
    SET IsSelected = 1
    WHERE Id = old.ParentId;
END;

CREATE TRIGGER T_Categories_IsSelectedChanged_false
AFTER UPDATE OF IsSelected ON Categories
FOR EACH ROW
WHEN NOT new.IsSelected
BEGIN
    UPDATE Categories 
    SET IsSelected = (SELECT IFNULL(MAX(IsSelected), 0)
                      FROM Categories
                      WHERE ParentId = old.ParentId)
    WHERE Id = old.ParentId;
END;
票数 0
EN

Stack Overflow用户

发布于 2015-05-25 06:55:52

您可以参考expr.html#case

我不确定,但你的代码可能是,

代码语言:javascript
运行
复制
CREATE TRIGGER T_Categories_IsSelectedChanged
UPDATE OF IsSelected ON Categories
BEGIN
case when new.isSelected then
    Update Categories Set IsSelected = True Where Id = old.ParentId;
else
    Update Categories Set IsSelected = Categories
        .Where(c => c.ParentId = old.ParentId)
        .Any(c => c.IsSelected);
END
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30432650

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档